欢迎来到天天文库
浏览记录
ID:38732645
大小:64.00 KB
页数:4页
时间:2019-06-18
《一步一步写算法(之非递归排序)》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、软件英才网软件行业驰名招聘网站一步一步写算法(之非递归排序)在上面一篇博客当中,我们发现普通查找和排序查找的性能差别很大。作为一个100万的数据,如果使用普通的查找方法,那么每一个数据查找平均下来就要几十万次,那么二分法的查找呢,20多次就可以搞定。这中间的差别是非常明显的。既然排序有这么好的效果,那么这篇博客中,我们就对排序算做一个总结。按照我个人的理解,排序可以分为两种:一种是非递归排序,它主要按照非递归的方法对数据进行排序,也就是说主要数据的移位和循环来完成;另外一种就是递归方法,我们在排列当前数据的时候首先把子数据排列有序,然后才会排
2、列当前的数据。这种不断递归调用的方法就是递归排序。非递归排序的方法很多,这里主要介绍冒泡排序、插入排序、希尔排序;递归的方法也不少,这里介绍的方法是快速排序、归并排序和堆排序。排序的内容很多,本篇博客主要介绍非递归排序,递归排序的内容主要在下一节内容解决。(1)冒泡排序冒泡排序的内容并不复杂。假设有n个数据需要排序,那么我们需要确定n个从大到小的数据,每一次都挑选第n大的数据是多少,并且放大相应的位置。直到所有的数据都排列整齐了,那么我们的排序就结束了。[cpp]viewplaincopy1voidbubble_sort(intarray[]
3、,intlength)2{3intinner=0,outer=0;4intmedian=0;56if(NULL==array
4、
5、0==length)7return;89for(outer=length-1;outer>=1;outer--){10for(inner=0;innerarray[inner+1]){12median=array[inner];13array[inner]=array[inner+1];14array[inner+1]=median;15}16}17
6、}18}那么这个程序有没有什么改进的地方呢?当然存在,如果发现在一次遍历循环之中,如果没有发生移位的现象,那么是不是可以判断这个排序可以结束了呢?朋友们可以好好思考一下这个问题?[cpp]viewplaincopy有需要请联系我们软件英才网软件行业驰名招聘网站1voidbubble_sort(intarray[],intlength)2{3intinner=0,outer=0;4intmedian=0;5intflag=1;67if(NULL==array
7、
8、0==length)8return;910for(outer=length-1;ou
9、ter>=1&&flag;outer--){11flag=0;1213for(inner=0;innerarray[inner+1]){15median=array[inner];16array[inner]=array[inner+1];17array[inner+1]=median;1819if(flag==0)20flag=1;21}22}23}24}(2)插入排序插入排序的意思就是说,我们把数据分成两个部分,一部分是已经排好序的数据,一部分是当前还没有完成排序的数据。
10、那么这么说来的话,排序的过程是不是就是把没有排序的数据逐个插入到已经排好序的队列中的过程呢。大家可以自己先试一下,然后再看看我的代码对不对?[cpp]viewplaincopy25voidinsert_sort(intarray[],intlength)26{27intinner=0;28intouter=0;29intmedian=0;30if(NULL==array
11、
12、0==length)31return;3233for(outer=1;outer13、nner=outer;inner>=1;inner--){2if(array[inner]14、它的基本思想是:首先按照一个序列递减的方法逐渐进行排序。比如说有10个数据,我们按照序列5、3、1的顺序进行排序。首先是5,那么我们对1和6、2和7、3和8、4和9
13、nner=outer;inner>=1;inner--){2if(array[inner]14、它的基本思想是:首先按照一个序列递减的方法逐渐进行排序。比如说有10个数据,我们按照序列5、3、1的顺序进行排序。首先是5,那么我们对1和6、2和7、3和8、4和9
14、它的基本思想是:首先按照一个序列递减的方法逐渐进行排序。比如说有10个数据,我们按照序列5、3、1的顺序进行排序。首先是5,那么我们对1和6、2和7、3和8、4和9
此文档下载收益归作者所有