首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

算法一看就懂之“选择排序”

下面我们来详细了解下一下它的逻辑。

一、「 选择排序 」是什么?

选择排序也是一种很简单的排序算法,它的思路也是将一组待排序的数据,分成2段,一段是“已排序”了的数据,另一段是“未排序”的数据。当然,在最开始的时候,“已排序”区段里是没有数据的。排序开始后,每次都从“未排序”的数据中取出一个最小的元素(注意,这里是取最小的元素,这一点与「 插入排序 」是不同的),然后将这个最小的元素插入到“已排序”数据中末尾元素的后面(这里其实是将这个最小元素与“已排序”数据的末尾紧邻的下一位元素进行交换),这样保持了“已排序”中的数据永远是有序的。一直这么循环的去处理,直到所有的“未排序”的数据都已交换完,则整个排序全部完成。

下面用图示例讲解一下:

(图片来源网络)

从上图可以看到,初始数组是

要对这个数组进行从小到大排序,默认初始状态是全部无序的,因此对这个数组开始遍历找最小元素。

第一遍大循环时,在整个数组中找到最小元素“13”,将这个最小元素“13”与数组的开头位置元素“29”进行交换。交换后数组为:

第二遍大循环时,元素“13”属于“已排序”区段了,剩下所有元素都属于“未排序”的区段。从剩下元素中找到最小元素“29”,将这个最小元素“29”与元素“72”进行交换(因为元素“72”是已排序数组紧邻的后一位元素),交换后数组为:

第三遍大循环时,“已排序”区段里已经有元素“13”、“29”了,剩下其它元素都属于“未排序”的。从剩下元素中找到最小元素“36”,将这个最小元素“36”与元素“98”进行交换(因为元素“98”是已排序数组紧邻的后一位元素),交换后数组为:

第四遍大循环时,“已排序”区段里已经有元素“13”、“29”、“36”了,剩下其它元素都属于“未排序”的。从剩下元素中找到最小元素“51”,将这个最小元素“51”与元素“72”进行交换(因为元素“72”是已排序数组紧邻的后一位元素),交换后数组为:

第五遍大循环时,“已排序”区段里已经有元素“13”、“29”、“36”、“51”了,剩下其它元素都属于“未排序”的。从剩下元素中找到最小元素“52”,将这个最小元素“52”与元素“87”进行交换(因为元素“87”是已排序数组紧邻的后一位元素),交换后数组为:

第六遍大循环时,“已排序”区段里已经有元素“13”、“29”、“36”、“51”、“52”了,剩下其它元素都属于“未排序”的。从剩下元素中找到最小元素“66”,发现这个最小元素“66”已经是位于已排序数组紧邻的后一位元素了,因此无需交换,数组保持不变:

第七遍大循环时,“已排序”区段里已经有元素“13”、“29”、“36”、“51”、“52”、“66”了,剩下其它元素都属于“未排序”的。从剩下元素中找到最小元素“72”,将这个最小元素“72”与元素“87”进行交换(因为元素“87”是已排序数组紧邻的后一位元素),交换后数组为:

第八遍大循环时,“已排序”区段里已经有元素“13”、“29”、“36”、“51”、“52”、“66”、“72”了,剩下其它元素都属于“未排序”的。从剩下元素中找到最小元素“87”,发现这个最小元素“87”已经是位于已排序数组紧邻的后一位元素了,因此无需交换,数组保持不变:

第九遍大循环时,“已排序”区段里已经有元素“13”、“29”、“36”、“51”、“52”、“66”、“72”、“87”了,剩下未排序的元素只有“98”这一个了,直接保持其位置不变即可,即,此时全部排序完成,数组最终状态为:

下面我们来看一个选择排序的代码示意:

二、「 选择排序 」的性能怎么样?

我们按照之前文章中讲到的排序算法评估方法来对「 选择排序 」进行一下性能评估:

时间复杂度:

选择排序原理就是在两层嵌套循环里进行对比和交换,所以简单来讲,其一般情况下的时间复杂度就是O(n*n)了。但如果仔细去分析的话,就得看具体的数据情况。但无论数据情况是怎样的,其元素比较的次数是一样的,因此无论是最好情况还是最坏情况,它的元素比较次数没区别。那再看看元素交换次数,如果待排序的数据本身就是有序的,其根本不需要交换元素,交换次数为0,但如果待排序的数据全部都是逆序的,那需要做n-1次元素交换。

因此,其选择排序的最好、最坏、平均情况下,其时间复杂度都是:O(n*n)。

空间复杂度:

选择排序完全就是比较和交换数据,只需要一个辅助空间用来存储待比较的元素的小标,并没有消耗更多的额外空间,因此其空间复杂度是O(1)。

排序稳定性:

选择排序算法不是稳定性排序算法。这里再解释一下稳定性排序是指:2个相等的元素,在排序前的相对前后位置和排序完成后的,相对前后位置保持一致。

选择排序为啥不是稳定性排序呢,举个例子:数组 6、7、6、2、8,在对其进行第一遍循环的时候,会将第一个位置的6与后面的2进行交换。此时,就已经将两个6的相对前后位置改变了。因此选择排序不是稳定性排序算法。

算法复杂性:

选择排序的算法无论是其设计思路上,还是代码的编写上都不复杂,其算法复杂性是较为简单的。

以上,就是对数据结构中「 选择排序 」的一些思考,您有什么疑问吗?

码字不易啊,喜欢的话不妨转发朋友,或点击文章右下角的“在看”吧。

本文原创发布于微信公众号「 不止思考 」,欢迎关注。涉及 思维认知、个人成长、架构、管理、Web技术 等。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20191107A02W6R00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券