冒泡排序和选择排序

本文详细介绍了冒泡排序和选择排序的原理、过程,并针对两者进行了优化分析。冒泡排序通过相邻元素比较并交换,选择排序则寻找最小值的索引并交换。冒泡排序在大小顺序问题时频繁交换,效率较低,而选择排序效率较高,推荐使用。
摘要由CSDN通过智能技术生成

冒泡排序和选择排序

冒泡排序

原理:相邻的两个单位,比较存储的数据,如果第一个单元的数据较大,就将两个相邻单元,交换存储数据

过程:从起始单元开始比较,第一次循环,会选择出一个最大值,放在数组所有单元的最后,之后每次循环,都会比较出一个本次循环的最大值,放在当前参与比较单元的最后,之前已经比较选出的单元,不会参与下一次比较

核心:交换存储的数据。两个相邻的单元,比较数据大小,第一个单元数值比较大,就交换两个单元存储的数据

优化

  1. 单次循环,最后一个单元,通过倒数第二个单元,参与比较。最后一个单元,就不参与单次循环
  2. 之前比较出的最大值,不在参与下一次的比较
  3. n个单元,只要循环比较n-1次,最后就一个单元时,不再循环比较
// 外层循环,循环执行排序操作,循环次数是数组单元个数-1
for(var j = 0 ; j <= (arr.length-1) -1 ; j++){
   

    // 内层循环,每次循环比较一个最大值
    // 上一次比较出的数值,不参与下一次循环 -j
    // 当次循环的最后一个单元,通过倒数第二个单元,参与比较不参与循环 -1
    for (var i = 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值