美文网首页
【排序】选择排序

【排序】选择排序

作者: dshowing | 来源:发表于2019-06-04 11:19 被阅读0次

选择排序(Selection sort)是一种简单直观的排序算法,将数列分为两部分:排序部分和待选择部分,每次从待选择的数列选出最大或者最小的元素放置于起始位置。

算法思想

  • 将第一个作为比较元素,一次和后边的比较,完事儿找到最小的元素,和第一个元素比较;
  • 重复操作,直到找到第二小的元素和第二个元素互换,以此类推

代码实现

def selection_sort(arr):
    """选择排序"""
    # 第一层for表示循环选择的遍数
    for i in range(len(arr) - 1):
        # 将起始元素设为最小元素
        min_index = i
        # 第二层for表示最小元素和后面的元素逐个比较
        for j in range(i + 1, len(arr)):
            if arr[j] < arr[min_index]:
                # 如果当前元素比最小元素小,则把当前元素角标记为最小元素角标
                min_index = j
        # 查找一遍后将最小元素与起始元素互换
        arr[min_index], arr[i] = arr[i], arr[min_index]
    return arr

算法分析

与冒泡不同的是,每次只有一次数据交换,因而可以减少CPU消耗,实际使用还是少

  • 比较性:需要比较来处理,属于比较排序
  • 稳定性:与冒泡不同,因为不是相邻元素交换,所以肯定会发生相同元素之间的换位,所以属于不稳定排序
  • 时间复杂度:与冒泡一样,同样是双层循环n(n-1),所以是O(n^2)
  • 空间复杂度:只需常数辅助单元,所以是O(1)
  • 内层循环做对比的时候,遇到小的元素只是先更改min_index的指向,等到一轮内层循环结束才会进行数据交换,因为内层只有一次数据交换。

相关文章

  • 常见排序算法

    这里介绍四种排序算法,选择排序、快速排序、归并排序、计数排序 选择排序(使用递归) 选择排序(使用循环) 快速排序...

  • 记录几个常见的排序算法

    常见的排序有:快速排序、冒泡排序、希尔排序、选择排序、插入排序、归并排序 冒泡排序: 插入排序: 选择排序: 希尔...

  • 排序 -- 选择/插入

    聊聊排序吧 冒泡排序 选择排序 插入排序 快速排序 归并排序 计数排序 桶排序 堆排序 本篇 选择排序与插入排序 ...

  • Java 常见的 8 种排序算法(内排序)

    排序分类 内部排序 插入排序:直接插入排序、希尔排序 交换排序:冒泡排序、快速排序 选择排序:直接选择排序、堆排序...

  • 排序法

    排序分 内部排序和外部排序 内部排序: 插入排序:{直接插入排序,希尔排序} 选择排序:{简单选择排序,堆排序} ...

  • 给自己备份的排序代码

    交换排序 冒泡排序 快速排序 插入排序 直接插入排序 希尔排序 选择排序 简单选择排序 堆排序

  • 算法-选择排序

    算 法:选择排序算法时间复杂度: 选择排序算法概述 选择排序伪代码 选择排序实现 选择排序算法概述 排序算法有许...

  • 算法与数据结构知识汇总(八、常见的八大排序算法)

    排序技术有:插入排序(直接插入排序、希尔排序)、选择排序(简单选择排序、堆排序)、交换排序(冒泡排序、快速排序)、...

  • 常用的两种排序-冒泡、选择

    Swift版 冒泡排序 选择排序 OC版 冒泡排序 选择排序

  • 算法

    排序 类型交换排序:冒泡排序、快速排序插入排序:直接插入排序、希尔排序选择排序:直接选择排序、堆排序归并排序基数排...

网友评论

      本文标题:【排序】选择排序

      本文链接:https://www.haomeiwen.com/subject/uxklxctx.html