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)
では最後まで実行されません。
一体なぜなんでしょうか?
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/04/06 10:17
2020/04/06 11:19