Python 实现选择排序

选择排序算法步骤:

  1. 找到数组中最小的那个元素中,
  2. 将它和数组的第一个元素交换位置,
  3. 在剩下的元素中找到最小的元素,将它和数组的第二个元素交换位置,
  4. 如此往复,知道将整个数组排序。

逐步分析:

  1. 假设一个数组有 6 个元素,
    [5, 1, 4, 3, 2, 6]
  2. 第 1 个元素为 5,与剩余 5 个元素相比,1 是最小的元素,所以 5 和 1 交换位置,
    [1, 5, 4, 3, 2, 6]
  3. 第 2 个元素为 5,与剩余 4 个元素相比, 2 是最小的元素,所以 5 和 2 交换位置,
    [1, 2, 4, 3, 5, 6]
  4. 第 3 个元素为 4,与剩余 3 个元素相比, 3 是最小的元素,所以 4 和 3 交换位置,
    [1, 2, 3, 4, 5, 6]
  5. 不断重复直到排好序。
def select_sort(arr):
    # 索引从 0 到 n-2
    for i in range(len(arr) - 1):
        # 最小元素的索引
        min = i
        # min 与从 i+1 到 n-1 的元素比较
        j = i + 1
        while j < len(arr):
            if arr[min] > arr[j]:
                # 找到最小的元素
                min = j
            j += 1
        # 交换位置
        arr[i], arr[min] = arr[min], arr[i]


a = [5, 1, 4, 3, 2, 6]
select_sort(a)
print(a)

稳定性:不稳定
复杂度:
平均 O(n^2)
最坏 O(n^2)
最好 O(n^2)

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

相关阅读更多精彩内容

  • 1 初级排序算法 排序算法关注的主要是重新排列数组元素,其中每个元素都有一个主键。排序算法是将所有元素主键按某种方...
    深度沉迷学习阅读 5,377评论 0 1
  • 选择排序,简单而直观,其原理是把序列中的最小值或者最大值找出来放在起始位置,然后再从剩下的序列中找出极值放到起始位...
    Python之战阅读 3,226评论 0 4
  • 知 识 点 / 超 人 数据结构算法排序是比较枯燥的知识,学习一定要耐着性子看,不然很容易理解错误。本文比较适合自...
    树下敲代码的超人阅读 10,642评论 9 58
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 10,606评论 0 52
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 5,036评论 0 2

友情链接更多精彩内容