冒泡排序,选择排序的应用

冒泡排序,选择排序的应用

冒泡排序

原理:
第一轮:
依次把列表中第一个元素与第二个元素比较,满足条件互换位置
接着把列表的第二个元素与第三个元素比较,满足条件互换位置

第二轮:
把列表的第二个元素与第三个元素比较,满足条件互换位置
把列表的第三个元素与第四个元素比较,满足条件互换位置
直到倒数第二个与倒数第一个比较
在这里插入图片描述
代码如下:
在这里插入图片描述

选择排序

原理:
从起始位置开始,找最小的数值所在的索引下标
如果最终存储的索引下标,不是起始位置,就与起始位置交换存储数据
执行一次循环,会将最小值存储在起始位置上
下一次循环,之前的起始位置,不再参与循环
外层循环:实现循环次数,是数组单元个数-1
内层循环:每次循环,将本次循环找出来的最小值,与起始位置进行数值交换
先默认起始位置的数值为最小值,存储起始位置的索引值
之后从起始位置的下一个位置开始循环,生成之后的所有索引下标,
如果之后位置上的数值,小于存储的索引位置的数值,就存储这个数值的索引
循环结束,变量中存储本次内层循环选择出的最小值的索引下标
进行比较判断,如果这个索引值,不是起始索引值,就交换两个索引值对应的数据
在这里插入图片描述
代码如下:
在这里插入图片描述

总结:

排序算法
冒泡排序:
核心: 相邻两个单元,比较数值大小,如果触发条件就交换存储数值
优化: 内层优化1: 只循环至倒数第二个单元,通过i+1,跟最后一个单元比较
内层优化2: 之前比较出的最大值,不再参与下一次的比较
外层优化 : n个单元,只循环n-1次,最后只剩一个单元时,不用循环
选择排序:
核心: 从起始位置开始,与之后的单元比较,如果触发条件,存储这个单元的索引下标
循环结束,如果索引下标不是起始位置下标,交换存储数值
优化: 内层优化: 之前比较出的最大值,不再参与下一次的比较
外层优化 : n个单元,只循环n-1次,最后只剩一个单元时,不用循环
选择排序的效率优于冒泡排序
冒泡排序,触发条件就执行数据交换,数据交换的操作比较繁琐
选择排序,触发条件只存储索引下标,最后只执行一次数据交换
选择排序 数据交换执行次数,少于 冒泡排序
本次介绍就到这里了,谢谢逆战班带来的教程,我学到了很多。在这里将会继续闯下去,希望能闯出一片天地,希望大佬看到这篇文章,有什么不足的地方给我提出来,让我认识到不足之处,谢谢!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值