推广 热搜: 红书  page  数据  数据分析  关键词  搜索  小红  哪些  考试  论文 

【数据结构与算法】排序算法——选择排序

   日期:2025-01-02     移动:https://sicmodule.kub2b.com/mobile/quote/18118.html

选择排序

上一篇我们讲了冒泡排序,这次来讲下另外一种比较排序——选择排序。在代码实现上选择排序跟冒泡排序有点像。因为很多时候看到初学者往往都会把冒泡排序跟选择排序在代码上搞混。为什么像呢?看看下面实现原理及代码。

算法实现原理

直接选择排序:直接选择排序的作法是:第一趟扫描所有数据,选择其中最小的一个与第一个数据互换;第二趟从第二个数据开始向后扫描,选择最小的与第二个数据互换;依次进行下去,进行了(n-1)趟扫描以后就完成了整个排序过程。

每一轮比较找到一个极值(最大值或最小值)放到某一端,对剩下的数再找极值,直至比较结束。

动图演示

代码实现

基本实现
 
优化实现:二元选择排序(1)

每次确定两个数(最大值和最小值,减少迭代次(用双循环实现不需要像下面的方法那样多重判断且考虑等值情况

 
优化实现:二元选择排序(2

使用单循环多判断实现

 
优化实现:等值情况

二元选择排序的时候,每一轮可以知道最大值和最小值,如果某一轮最大最小值都一样了,说明剩下的数字都是相等的,直接结束排序。

 
优化实现:等值情况优化

如果 = ,找到最大值索引为-5, 最小值索引为1,上面代码会交换两次,第二次的两个1交换是多余的操作,所以添加一个判断,如果值相同则不交换。

 
堆排序

堆排序实际上也是一种选择排序,但其时间复杂度是O(nlogn)。这涉及到二叉堆的知识,这里先不做详细介绍,后续会有专门讲解堆排序的文章。

 

时间复杂度

维度复杂度最坏时间复杂度O(n2)最优时间复杂度O(n2)平均时间复杂度O(n2

空间复杂度

本文地址:https://sicmodule.kub2b.com/quote/18118.html     企库往 https://sicmodule.kub2b.com/ , 查看更多

特别提示:本信息由相关用户自行提供,真实性未证实,仅供参考。请谨慎采用,风险自负。


0相关评论
相关最新动态
推荐最新动态
点击排行
网站首页  |  关于我们  |  联系方式  |  使用协议  |  版权隐私  |  网站地图  |  排名推广  |  广告服务  |  积分换礼  |  网站留言  |  RSS订阅  |  违规举报  |  鄂ICP备2020018471号