2017年09月19日
《その33》 配列の要素の並びの変更(p.181演習5-8),配列のコピー(p.183演習5-9)
新版明解C++入門編 p.181 演習5-8
配列の並びをシャッフルする(要素の並びがランダムになるようにかき混ぜる)プログラムを作成せよ。
// p181_演習5-8
#include <iomanip>
#include <ctime>
#include <cstdlib>
#include <iostream>
using namespace std;
int main()
{
const int n = 6;
int a[n];
int b[n]; // シャッフル後の要素順に値を格納
int idx[n]; // 0〜nの異なるn個の整数をランダムに格納
srand(unsigned int(time(NULL)));
cout << "シャッフル前 … ";
for (int i = 0; i < n; i++) {
a[i] = rand() % 100;
cout << "a[" << i << "] = " << setw(2) << a[i] << ' ';
}
cout << '\n';
for (int i = 0; i < n; i++) {
bool fail = false; // idx[i]の値に重複が無ければfalse,あればtrue
do {
idx[i] = rand() % n;
for (int j = 0; j < i; j++) {
if (idx[i] == idx[j]) {
fail = true; break;
}
else
fail = false;
}
b[i] = a[idx[i]];
} while (fail);
}
cout << "シャッフル後 … ";
for (int i = 0; i < n; i++) {
a[i] = b[i]; // 配列aを配列bで上書き
cout << "a[" << i << "] = " << setw(2) << a[i] << ' ';
}
cout << '\n';
}
新版明解C++入門編 p.183 演習5-9
配列aの全要素を配列bに対して逆順にコピーするプログラムを作成せよ。
// p183_演習5-9
#include <iostream>
using namespace std;
int main()
{
const int n = 5;
int a[n];
int b[n];
cout << "整数値を入力\n";
for (int i = 0; i < n; i++) {
cout << "a[" << i << "] : "; cin >> a[i];
}
cout << '\n';
for (int i = 0; i < n; i++)
b[i] = a[n - i - 1];
for (int i = 0; i < n; i++)
cout << "b[" << i << "] = " << b[i] << '\n';
}
--
この記事へのコメント
コメントを書く
この記事へのトラックバックURL
https://fanblogs.jp/tb/6719125
※ブログオーナーが承認したトラックバックのみ表示されます。
この記事へのトラックバック