質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Q&A

解決済

2回答

347閲覧

同じ値を代入しているのに、書き方によって実行結果が違うのはなぜ

GIOGIO

総合スコア23

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

0グッド

0クリップ

投稿2020/04/06 09:42

C

1#include <stdio.h> 2#define SIZE 40 3 4void shell_sort(int[], int); 5 6int main() 7{ 8 int array[SIZE] = {3,5,4,3,7,6,8,9,67,54,32,4,6,5,4,3,56,7,87,0,9,87,2,1,2,33,43,1,2,3,4,21,2,3,4,5,6,32,11,80}; 9 int i; 10 11 printf("Before sort: "); 12 for (i = 0; i < SIZE; i++) { 13 printf("%d ", array[i]); 14 } 15 printf("\n"); 16 17 shell_sort(array, SIZE); 18 19 printf("After sort: "); 20 for (i = 0; i < SIZE; i++) { 21 printf("%d ", array[i]); 22 } 23 printf("\n"); 24 return 0; 25} 26 27void swap(int *x, int *y) { 28 int temp; 29 temp = *x; 30 *x = *y; 31 *y = temp; 32}

下2つのシェルソート関数の
for (H = 1; H <= array_size/9; H = 〜)
の箇所を見比べてみて下さい。

C

1// シェルソート 2void shell_sort(int array[], int array_size) { 3 4 // 間隔Hを決める 5 int H; 6 // データ数が9以上の時、間隔を4にする 7 for (H = 1; H <= array_size/9; H = 4); 8 for ( ; H > 0; H /= 3) { 9 int i; 10 for (i = H; i < array_size; i++) { 11 while ((i > H-1) && (array[i-H] > array[i])) { 12 swap(&array[i-H], &array[i]); 13 i -= H; 14 } 15 } 16 } 17} 18/* 19実行結果: Before sort: 3 5 4 3 7 6 8 9 67 54 32 4 6 5 4 3 56 7 87 0 9 87 2 1 2 33 43 1 2 3 4 21 2 3 4 5 6 32 11 80 20 21*/

C

1// シェルソート 2void shell_sort(int array[], int array_size) { 3 4 // 間隔Hを決める 5 int H; 6 // データ数が9以上の時、間隔を4にする 7 for (H = 1; H <= array_size/9; H = H*3 + 1); 8 for ( ; H > 0; H /= 3) { 9 int i; 10 for (i = H; i < array_size; i++) { 11 while ((i > H-1) && (array[i-H] > array[i])) { 12 swap(&array[i-H], &array[i]); 13 i -= H; 14 } 15 } 16 } 17} 18/* 19実行結果: Before sort: 3 5 4 3 7 6 8 9 67 54 32 4 6 5 4 3 56 7 87 0 9 87 2 1 2 33 43 1 2 3 4 21 2 3 4 5 6 32 11 80 20After sort: 0 1 1 2 2 2 2 3 3 3 3 3 4 4 4 4 4 5 5 5 6 6 6 7 7 8 9 9 11 21 32 32 33 43 54 56 67 80 87 87 21 22*/

for (H = 1; H <= array_size/9; H = H*3 + 1)
と書いたら最後まで実行されるのに

for (H = 1; H <= array_size/9; H = 4)
では最後まで実行されません。
一体なぜなんでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

同じ値を代入しているのに

同じ値ではありません。前者ではHが1→4→13→40と進んでいきます。

投稿2020/04/06 09:52

maisumakun

総合スコア146018

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

GIOGIO

2020/04/06 10:17

どのタイミングで変化しているのでしょうか?
maisumakun

2020/04/06 11:19

ループを1回回るごとに、 H = H*3 + 1が実行されます。
guest

0

for文の理解が足りていません。
H = H*3 + 1の場合は、Hの値が変化しますが、H = 4の場合、無限ループとなります。

投稿2020/04/06 09:55

kaina

総合スコア418

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問