逆転させようとしている数字の配列があります。私のコードの関数は正しいと思いますが、適切な出力が得られません。
出力は次のようになります。10 9 8 7 6. なぜ残りの半分の数字を得ることができないのでしょうか?countから"/2"を取り除くと、出力は次のようになります。10 9 8 7 6 6 7 8 9 10
void reverse(int [], int);
int main ()
{
const int SIZE = 10;
int arr [SIZE] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
reverse(arr, SIZE);
return 0;
}
void reverse(int arr[], int count)
{
int temp;
for (int i = 0; i < count/2; ++i)
{
arr[i] = temp;
temp = arr[count-i-1];
arr[count-i-1] = arr[i];
arr[i] = temp;
cout << temp << " ";
}
}
ライン
arr[i] = temp;
の部分が間違っています。 (ループの最初の繰り返しでは arr[i]
が未定義の値に設定され、それ以降の繰り返しでは正しくない値に設定されます)。この行を削除すると、配列が正しく反転します。
その後,反転した配列を表示するコードを,リスト全体を反復する新しいループに移す必要があります。 現在のコードでは、最初の count/2
個の要素だけを表示しています。
int temp, i;
for (i = 0; i < count/2; ++i) {
temp = arr[count-i-1];
arr[count-i-1] = arr[i];
arr[i] = temp;
}
for (i = 0; i < count; ++i) {
cout << arr[i] << " ";
}