堅持真的是最難的事,上次寫代碼已經是十幾天之前了。
//希爾排序 2013/09/22
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <malloc.h>
//path爲步長,正常的插入排序調用是insertSort(a,n,0,1)
void insertSort(int* a,int n, int start, int path){
int i,j,t;
for (i=start + path ; i < n ; i += path){
t = a[i]; //我錯寫成過t = a[j]
for( j = i; j >= start + path && t < a[j-path]; j -= path){
a[j] = a[j - path];
}
a[j] = t;
}
}
//shell排序本質上是分組的插入排序
//通過比較相隔較遠距離(稱爲增量或步長)的數,使得數移動時能跨過多個元素,則進行一次比較就可能消除多個元素交換
void shellSort(int* a,int n){
int start;
int path;
//初次步長設爲n/2,每次循環步長減半,直到爲1
for(path = n/2; path > 0; path /= 2){
for(start = 0; start < path; start++){
//調用插入排序
insertSort(a,n,start,path);
}
}
}
void initArr(int* a, int n){
int i;
srand(time(NULL));
for(i = 0; i < n; i++){
a[i] = rand()%100;
}
}
void printArr(int* a, int n){
int i;
for (i = 0;i < n; i++){
printf("%d,",a[i]);
}
printf("\n");
}
void main(){
int* arr;
int n;
printf("Input the size of array:");
scanf("%d",&n);
arr = (int *)malloc(n*sizeof(int));
initArr(arr,n);
printArr(arr,n);
shellSort(arr,n);
printArr(arr,n);
}