算法06-2选择排序

选择排序的概念:

它是一种简单直观的排序算法。它工作原理如下。首先在未排序序列(右边无序)中找到最小(或最大)元素,置换至序列的起始位置(左边有序),然后在从剩余部分未排序的元素中继续寻找最小(或最大)元素,然后放到已排序的末尾、以此类推知道所有元素均排序完毕。

选择排序的优点与数据移动有关。如果某个元素位于正确的最终位置上,则它不会移动。选择排序每次交换一次元素,他们当中至少有一个将被移动到其最终的位置上,因此对N个元素的表进行排序总共进行最多N-1次交换。在所有的完全依靠交换去移动元素的排序方法中,选择排序属于非常好的一种。

选择排序的时间复杂度:

最优时间复杂度:O(n²)

最坏时间复杂度:O(n²)

稳定性:不稳定(以升序排序,每次选择最大的情况)



©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 稳定:如果a原本在b前面,而a=b,排序之后a仍然在b的前面;不稳定:如果a原本在b的前面,而a=b,排序之后a可...
    意识流丶阅读 8,416评论 2 9
  • 简单来说,时间复杂度指的是语句执行次数,空间复杂度指的是算法所占的存储空间 时间复杂度计算时间复杂度的方法: 用常...
    Teci阅读 4,804评论 0 1
  • 概述 因为健忘,加上对各种排序算法理解不深刻,过段时间面对排序就蒙了。所以决定对我们常见的这几种排序算法进行统一总...
    清风之心阅读 4,032评论 0 1
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 10,601评论 0 52
  • 排序算法基础 排序算法,是一种能将一串数据按照特定的排序方式进行排列的一种算法,一个排序算法的好坏,主要从时间复杂...
    jackyshan阅读 9,628评论 3 11

友情链接更多精彩内容