js冒泡排序 js冒泡排序代码从大到小排序
一、Java中的冒泡排序是如何实现的
谢邀。冒泡排序还是比较好理解的,主要是要理解其核心思想。如果从小到大排序,每一轮排序就找出未完成排序序列中的最大值,然后放在最后,直到排序完成为止。
(冒泡排序过程及结果展示)
一般而言,冒泡排序有以下步骤:
设数组长度为N,比较前后相邻的两个数据,如果前值大于后值,就将这两个值交换。
重复以上步骤,从第0个数据到N-1个数据进行遍历,最大值就会沉在下方。
以上就是冒泡排序的基本思想,按照这个定义很快就能写出代码:
测试代码:
运行结果如下:
0,1,1,2,3,3,4,7,8,9,12,22,65当然,如果序列本身有一部分是有序序列,或者本来就排序已经完成,那么遍历会带来不少开销,可以设置一个布尔值进行开关操作。如果已经完成排序,那么中止遍历,如果未完成,继续遍历。
如果你对学习人工智能和科技新闻感兴趣,可以订阅我的头条号,我会在这里发布所有与算法、机器学习以及深度学习有关的有趣文章。偶尔也回答有趣的问题,有问题可随时在评论区回复和讨论,看到即回。
(码字不易,若文章对你帮助可点赞支持~)
二、冒泡排序的规则
1)基本思想
冒泡排序的基本思想就是:从无序序列头部开始,进行两两比较,根据大小交换位置,直到最后将最大(小)的数据元素交换到了无序队列的队尾,从而成为有序序列的一部分;下一次继续这个过程,直到所有数据元素都排好序。
算法的核心在于每次通过两两比较交换位置,选出剩余无序序列里最大(小)的数据元素放到队尾。
(2)运行过程
冒泡排序算法的运作如下:
1、比较相邻的元素。如果第一个比第二个大(小),就交换他们两个。
2、对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大(小)的数。
3、针对所有的元素重复以上的步骤,除了最后已经选出的元素(有序)。
4、持续每次对越来越少的元素(无序元素)重复上面的步骤,直到没有任何一对数字需要比较,则序列最终有序。
三、C语言冒泡排序
将被排序的记录数组R[1..n]垂直排列,每个记录R看作是重量为R.key的气泡。
根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R:凡扫描到违反本原则的轻气泡,就使其向上"飘浮"。
如此反复进行,直到最后任何两个气泡都是轻者在上,重者在下为止。