一日一碼05--希爾排序

堅持真的是最難的事,上次寫代碼已經是十幾天之前了。


//希爾排序	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);

}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章