C语言9种常用排序法讲解.doc

  1. 1、本文档共20页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C语言9种常用排序法 1. HYPERLINK \l _1.冒泡排序 冒泡排序 2. HYPERLINK \l _2.选择排序 选择排序 3. HYPERLINK \l _4.插入排序法 插入排序 4. HYPERLINK \l _3.快速排序 快速排序 5. HYPERLINK \l _5.shell排序法 希尔排序 6. HYPERLINK \l _6.归并排序 归并排序 7. HYPERLINK \l _7.堆排序 堆排序 8. HYPERLINK \l _8._带哨兵的直接插入排序 带哨兵的直接插入排序 9. HYPERLINK \l _9.基数排序 基数排序 例子:乱序输入n个数,输出从小到大排序后的结果 1.冒泡排序 #includestdio.h int main() { int i, j, n, a[100], temp; while(scanf(%d,n)!=EOF) { for(i=0;in;i++) scanf(%d,a[i]); for(i=0;in-1;i++) //总共需冒泡n-1次 { for(j=0;jn-i-1;j++) //第i趟冒泡 { if(a[j]a[j+1]) //比较a[j]与a[j+1],使a[j+1]大于a[j] { temp = a[j+1]; a[j+1] = a[j]; a[j] = temp; } } } for(i=0;in;i++) //打印 printf(%d ,a[i]); printf(\n); } return 0; } 2.选择排序 #includestdio.h int main() { int i, j, n, a[100], t, temp; while(scanf(%d,n)!=EOF) { for(i=0;in;i++) scanf(%d,a[i]); for(i=0;in-1;i++) //总共排序n-1趟 { t = i; for(j=i+1;jn;j++) //第i趟从a[i+1]~a[n-1]中选最小的数与a[i]交换 { if(a[t]a[j]) t = j; } temp = a[i]; a[i] = a[t]; a[t] = temp; } for(i=0;in;i++) printf(%d ,a[i]); printf(\n); } return 0; } 3.快速排序 /* 1.假设数组为a[n]; 2.第一次排序过程如下: 取x = 0 ( a[0]为中轴 ); i=0 (第一个元素下标), j=n-1(最后一个元素下标); 重复下面过程:(直到i=j) { 从a[j]起,向前找小于a[x]的元素,同时j--,找到后,a[j]与a[x]交换,x=j; 从a[i]起,向后找大于a[x]的元素,同时i++,找到后,a[i]与a[x]交换,x=i; } 3.注意快排函数是迭代函数,必须要有结束条件 (因为忽略结束条件,调试了很久......) 4.再对a[low]~a[x-1]、a[x+1]~a[high]分别调用快排函数 */ #includestdio.h void quicksort(int a[],int low,int high); int main() { int i, n, a[100]; while(scanf(%d,n)!=

文档评论(0)

shuwkb + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档