首页建站js冒泡排序 js冒泡排序代码从大到小排序

js冒泡排序 js冒泡排序代码从大到小排序

编程之家2024-02-2599次浏览

一、Java中的冒泡排序是如何实现的

谢邀。冒泡排序还是比较好理解的,主要是要理解其核心思想。如果从小到大排序,每一轮排序就找出未完成排序序列中的最大值,然后放在最后,直到排序完成为止。

js冒泡排序 js冒泡排序代码从大到小排序

(冒泡排序过程及结果展示)

一般而言,冒泡排序有以下步骤:

设数组长度为N,比较前后相邻的两个数据,如果前值大于后值,就将这两个值交换。

重复以上步骤,从第0个数据到N-1个数据进行遍历,最大值就会沉在下方。

以上就是冒泡排序的基本思想,按照这个定义很快就能写出代码:

测试代码:

js冒泡排序 js冒泡排序代码从大到小排序

运行结果如下:

0,1,1,2,3,3,4,7,8,9,12,22,65

当然,如果序列本身有一部分是有序序列,或者本来就排序已经完成,那么遍历会带来不少开销,可以设置一个布尔值进行开关操作。如果已经完成排序,那么中止遍历,如果未完成,继续遍历。

如果你对学习人工智能和科技新闻感兴趣,可以订阅我的头条号,我会在这里发布所有与算法、机器学习以及深度学习有关的有趣文章。偶尔也回答有趣的问题,有问题可随时在评论区回复和讨论,看到即回。

(码字不易,若文章对你帮助可点赞支持~)

二、冒泡排序的规则

1)基本思想

冒泡排序的基本思想就是:从无序序列头部开始,进行两两比较,根据大小交换位置,直到最后将最大(小)的数据元素交换到了无序队列的队尾,从而成为有序序列的一部分;下一次继续这个过程,直到所有数据元素都排好序。

js冒泡排序 js冒泡排序代码从大到小排序

算法的核心在于每次通过两两比较交换位置,选出剩余无序序列里最大(小)的数据元素放到队尾。

(2)运行过程

冒泡排序算法的运作如下:

1、比较相邻的元素。如果第一个比第二个大(小),就交换他们两个。

2、对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大(小)的数。

3、针对所有的元素重复以上的步骤,除了最后已经选出的元素(有序)。

4、持续每次对越来越少的元素(无序元素)重复上面的步骤,直到没有任何一对数字需要比较,则序列最终有序。

三、C语言冒泡排序

将被排序的记录数组R[1..n]垂直排列,每个记录R看作是重量为R.key的气泡。

根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R:凡扫描到违反本原则的轻气泡,就使其向上"飘浮"。

如此反复进行,直到最后任何两个气泡都是轻者在上,重者在下为止。

生日快乐简谱图片?生日快乐简谱简单版创意字体与编排设计?字体排版与设计