简单选择排序(C语言)_第1页
简单选择排序(C语言)_第2页
简单选择排序(C语言)_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、选择排序是排序算法的一种,这里以从小到大排序为例进行讲解。基本思想及举例说明 简单选择排序(从小到大)的基本思想是,首先,选出最小的数,放在第一个位置;然后,选出第二小的数,放在第二个位置;以此类推,直到所有的数从小到大排序。在实现上,我们通常是先确定第i小的数所在的位置,然后,将其与第i个数进行交换。下面,以对 3 2 4 1 进行选择排序说明排序过程,使用min_index 记录当前最小的数所在的位置。第1轮 排序过程 (寻找第1小的数所在的位置)3 2 4 1(最初, min_index=1)3 2 4 1(3 2, 所以min_index=2)3 2 4 1(2 1, 所以 min_i

2、ndex=4, 这时候确定了第1小的数在位置4)1 2 4 3 (第1轮结果,将3和1交换,也就是位置1和位置4交换)第2轮 排序过程 (寻找第2小的数所在的位置)1 2 4 3(第1轮结果, min_index=2,只需要从位置2开始寻找)1 2 4 3(4 2, 所以min_index=2)1 2 4 3(3 2, 所以 min_index=2)1 2 4 3(第2轮结果,因为min_index位置刚好在第2个位置,无需交换)第3轮 排序过程 (寻找第3小的数所在的位置)1 2 4 3(第2轮结果, min_index=3,只需要从位置2开始寻找)1 2 4 3(4 3, 所以min_in

3、dex=4)1 2 3 4(第3轮结果,将3和4交换,也就是位置4和位置3交换)至此,排序完毕。总结及实现 选择排序对大小为N的无序数组RN进行排序,进行N-1轮选择过程。第i轮选取第i小的数,并将其放在第i个位置上。当第N-1次完成时,第N小(也就是最大)的数自然在最后的位置上。下面给出选择排序的C语言实现。1. #include2. #include3. #include 4. using namespace std;5. 6. 7. voidselect_sort(inta,int&n);/采用c+中的引用操作;8. 9. /选择排序实现10. voidselect_sort(inta,

4、int&n)/n为数组a的元素个数11. 12. /进行N-1轮选择13. for(inti=1-1;i=i;j-)18. 19. if(ajamin)20. 21. min=j;22. 23. 24.25. /将第i小的数,放在第i个位置;如果刚好,就不用交换26. if(i!=min)27. 28. inttemp=ai;29. ai=amin;30. amin=temp;31. 32. 33. 34. 35. 36. intmain()37. 38. intnum=89,38,11,78,96,44,19,25;39. int N=sizeof(num)/sizeof(num0);/计算数组中元素的个数40.41. select_sort(num,N);42.43. for(inti=0;iN;i+)44. cout numiendl;45.46. system(pause);47. return0;48. 49. 注意:选择排序是一种不稳定的排序算法,可能会打乱两个相同数字的原有顺序。例如,序列 5 8 5

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论