细说冒泡排序及其五种优化算法 Posted 2021-04-07 程序大世界
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了细说冒泡排序及其五种优化算法相关的知识,希望对你有一定的参考价值。
“The first 90% of the code accounts for the first 90% of the development time. The remaining 10% of the code accounts for the other 90% of the development time.” - Tom Cargill
译文:“最开始的90%的代码使用了程序员 90%的时间,剩下的10%的代码也需要90%的开发时间。” - Tom Cargill
冒泡排序算法思想简单来说:在内层一次遍历中,arr[j] 与 arr[j - 1] 进行比较,如arr[j - 1] < arr[j], 不改变,反之互换值,保证arr[j]存储着 0~j - 1中的最大值,随一次遍历当前数组最大值也下沉至末尾,经过n - 1次外层循环,可使n - 1个元素下沉,最后一个元素位置确定,排序完成。
例1:例如原数组为: 0,34,66,12,100,98
从下标1的元素(即34)排起:34与0比较,34大,数组仍为 0,34,66,12,100,98
下标2的元素(即66):66与34比较,66大,数组仍为 0,34,66,12,100,98
下标3的元素(即12):12与66比较,12小,互换位置,数组变换为 0, 34,12,66,100,98
下标4的元素(即100):100与66比较,100大,数组仍为 0,34,12,66, 100,98
下标5的元素(即98):98与100比较,98小,则互换位置,数组变换为 0,34,12,66,98,100
查看规律,
排序过程中,下标 j的值在交换后,是0 ~ j - 1中最大的,利用的是不等号具有传递性;排序完成后,将100沉底,再进行新的循环时,只需排序 0, 34, 12, 66, 98 即可,最大值沉底。
举例2:假设元素数组为1, 0, 2, 4,8,那么只需一次内层遍历即完成了,何须四次?可优化为在每次遍历中增加一个tag记录,如果发生交换,则将tag = false,循环结束检测是否tag发生变化,未发生变化一定是排序完成。
如咱们的例1:在一次排序后数据变换为 0,34,12,66,98,100 , 那么第二次内层遍历只需遍历0, 34, 12即可,无需遍历至
0, 34, 12, 66, 98
,只需设置一个next记录最后交换位置,下一次循环就以next为终止。
举例3: 1000,2,34,56,343,0 ,一次下沉和上浮操作排序完成。虽然没有优化循环次数,但大大减少交换次数。
现生成30万条数据使用以上冒泡排序+五种优化算法测试,测试结果如下:
答:和初始数据有关,内外层皆优化中如果多次使用next记录,但最后一个数值仍需交换,白白浪费之前赋值时间,再加之逻辑判断,所以慢于原冒泡算法,但大部分情况下优于原算法。
答:因为在两者逻辑判断中boolean型比==快的多,用1亿条循环测试如下:
答:会,因数据和数据量的不同会发生一定变化,特定条件下还可能产生相反的结果。即使采用统一数据,也可能因为对不同算法产生相反的影响。
以上是关于细说冒泡排序及其五种优化算法的主要内容,如果未能解决你的问题,请参考以下文章
冒泡排序算法及其两种优化
交换排序------冒泡法 及其优化
排序算法入门之冒泡排序及其优化(java实现)
鸡尾酒算法排序
冒泡排序及其优化
算法初识:常用的五种排序算法-冒泡排序