预览加载中,请您耐心等待几秒...
1/8
2/8
3/8
4/8
5/8
6/8
7/8
8/8

在线预览结束,喜欢就下载吧,查找使用更方便

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

c语言经典排序算法(8种-含源代码).txt蜜蜂整日忙碌,受到赞扬;蚊子不停奔波,人见人打。多么忙不重要,为什么忙才重要。天行健,君子以自强不息 常见经典排序算法 1.希尔排序 2.二分插入法 3.直接插入法 4.带哨兵的直接排序法 5.冒泡排序 6.选择排序 7.快速排序 8.堆排序 一.希尔(Shell)排序法(又称宿小增量排序,是1959年由D.L.Shell提出来的) /*Shell排序法*/ #include<stdio.h> voidsort(intv[],intn) { intgap,i,j,temp; for(gap=n/2;gap>0;gap/=2)/*设置排序的步长,步长gap每次减半,直到减到1*/ { for(i=gap;i<n;i++)/*定位到每一个元素*/ { for(j=i-gap;(j>=0)&&(v[j]>v[j+gap]);j-=gap)/*比较相距gap远的两个元素的大小,根据排序方向决定如何调换*/ { temp=v[j]; v[j]=v[j+gap]; v[j+gap]=temp; } } } } 二.二分插入法 /*二分插入法*/ voidHalfInsertSort(inta[],intlen) { inti,j,temp; intlow,high,mid; for(i=1;i<len;i++) { temp=a[i];/*保存但前元素*/ low=0; high=i-1; while(low<=high)/*在a[low...high]中折半查找有序插入的位置*/ { mid=(low+high)/2;/*找到中间元素*/ if(a[mid]>temp)/*如果中间元素比但前元素大,当前元素要插入到中间元素的左侧*/ { high=mid-1; } else/*如果中间元素比当前元素小,但前元素要插入到中间元素的右侧*/ { low=mid+1; } }/*找到当前元素的位置,在low和high之间*/ for(j=i-1;j>high;j--)/*元素后移*/ { a[j+1]=a[j]; } a[high+1]=temp;/*插入*/ } } 三.直接插入法 /*直接插入法*/ voidInsertionSort(intinput[],intlen) { inti,j,temp; for(i=1;i<len;i++) { temp=input[i];/*操作当前元素,先保存在其它变量中*/ for(j=i-1;j>-1&&input[j]>temp;j--)/*从当前元素的上一个元素开始查找合适的位置*/ { input[j+1]=input[j];/*一边找一边移动元素*/ input[j]=temp; } } } 四.带哨兵的直接排序法 /** *带哨兵的直接插入排序,数组的第一个元素不用于存储有效数据 *将input[0]作为哨兵,可以避免判定input[j]中,数组是否越界 *因为在j--的过程中,当j减小到0时,变成了input[0]与input[0] *自身进行比较,很明显这个时候说明位置i之前的数字都比input[i]小 *位置i上的数字不需要移动,直接进入下一轮的插入比较。 * */ voidInsertionSortWithPiquet(intinput[],intlen) { inti,j; for(i=2;i<len;i++)/*保证数组input第一元素的存储数据无效,从第二个数据开始与它前面的元素比较*/ { input[0]=input[i]; for(j=i-1;input[j]>input[0];j--) { input[j+1]=input[j]; input[j]=input[0];/*input[j]一直都是排序的元素中最大的那一个*/ } } } 五.冒泡法 /*冒泡排序法*/ voidBublesort(inta[],intn) { inti,j,k; for(j=0;j<n;j++)/*气泡法要排序n次*/ { for(i=0;i<n-j;i++)/*值比较大的元素沉下去后,只把剩下的元素中的最大值再沉下去就可以啦*/ { if(a[i]>a[i+1])/*把值比较大的元素沉到底*/ { k=a[i]; a[i]=a[i+1]; a[i+1]=k; } } } } 六.选择排序法 /*算法原理:首先以一个元素为基准,从一个方向开始扫描, *比如从左至右扫描,以A[0]为基准。接下来从A[0]...A[9] *中找出最小的元素,将其与A[0]交换。然后将基准位置右 *移一位,重复上面的动作,比如,以A[1]为基准,找出 *A[1]~A[9]中最小的,将其与A[1]交换。