【Python排序算法系列】—— 选择排序

21dd41dce63a4f2da07b9d879ad0120b.png

🌈个人主页: Aileen_0v0
🔥热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法
💫个人格言:
"没有罗马,那就自己创造罗马~"


目录

选择排序 

过程演示:

选择排序实现代码:

分析选择排序:

Practice2:

📝总结:


选择排序 

过程演示:

首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置。

再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。

重复第二步,直到所有元素均排序完毕。

选择排序对冒泡排序进行了改进保留了其基本的多趟比对思路,每趟都使当前最小项就位。
但选择排序
对交换进行了削减,相比起冒泡排序进行多次交换,每趟仅进行1次交换,记录最小项的所在位置,最后再跟本趟第一项交换  ---> 两两对比,小(大)的放前(后)面,对比过程不发生交换。

选择排序的时间复杂度比冒泡排序稍优but

比对次数不变,还是0(n²)

交换次数减少为0(n)

选择排序实现代码:

#默认第一个是最小,然后与后面进行比较,遇到最小就交换,不影响比较过程。
def selectionSort(arr):
    # i : 记录当前位置的索引
    for i in range(len(arr)):
        #初始化变量positionMin 为 i, 记录最小元素的索引位置
        positionofMin = i #默认最小值的下标从0开始
        # j :记录后面待比较元素的位置索引
        for j in range(i + 1,len(arr)):
            #对比找到最小值,然后更新最小值下标
            if arr[positionofMin] > arr[j]:
                positionofMin = j
        #将最小元素 放到 已排好序部分的末尾
        arr[i],arr[positionofMin] = arr[positionofMin],arr[i]
    return arr

list = [5,3,1,4,2]
print(selectionSort(list))

分析选择排序:

选择排序算法和冒泡排序算法的比较次数相同,所以时间复杂度也是 O(n²)。但是,由于减少了交换次数,因此选择排序算法通常更快。

Practice2:

选择排序可以先排小的再排大的,也可以逆过来先排大的再排小的。

👇下面是我的解题思路:

这道题,我们可以一眼看出它是先排大的数再排小的数,因为如果先排小的数,应该是先排1,很明显没有这个选项。

所以,我们从后面开始,

第一轮:

20默认是最大开始往前比较找有没有比它还要大的值中的最大值,很显然没有,那我们继续往下面的元素8开始第二轮的对比。

第二轮:

倒数第二位的8,往前找比它大的数,与它前面所有比它大的数中的最大值【19】进行交换,8和19进行交换。

第三轮:

倒数第三位的18,往前找比它大的数,遗憾的是没有,所以就无需进行交换。

所以最终答案是: [11,7,12,14,8,1,6,18,19,20]

📝总结:

相关推荐

  1. 排序算法——选择排序

    2023-12-30 10:14:02       40 阅读
  2. 排序算法-选择排序

    2023-12-30 10:14:02       17 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-30 10:14:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-30 10:14:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-30 10:14:02       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-30 10:14:02       20 阅读

热门阅读

  1. Mongodb中一个有趣的数值查询案例

    2023-12-30 10:14:02       35 阅读
  2. TCP、IP、TCP/IP、HTTP和HTTPS协议简介

    2023-12-30 10:14:02       41 阅读
  3. h5 history模式是什么

    2023-12-30 10:14:02       36 阅读
  4. WPF 基础入门(XAML理解二)

    2023-12-30 10:14:02       36 阅读
  5. Linux 赛题FTP配置

    2023-12-30 10:14:02       36 阅读
  6. 第三篇 结构型设计模式 - 简化复杂系统的结构

    2023-12-30 10:14:02       35 阅读
  7. flutter实践:Isolate应用实例二

    2023-12-30 10:14:02       38 阅读
  8. 不同开源协议之间的差异分析

    2023-12-30 10:14:02       31 阅读
  9. go语言orm框架go-pg如何修改单列/多列、原地运算

    2023-12-30 10:14:02       38 阅读