当前位置: 首页 > ds >正文

数据结构-选择排序(Python)

目录

选择排序算法思想

选择排序算法步骤 

选择排序代码实现 

选择排序算法分析


选择排序算法思想

选择排序(Selection Sort)基本思想

将数组分为两个区间:左侧为已排序区间,右侧为未排序区间。每趟从未排序区间中选择一个值最小的元素,放到已排序区间的末尾,从而将该元素划分到已排序区间

选择排序是一种简单直观的排序算法,其思想简单,代码也相对容易。

选择排序算法步骤 

假设数组的元素个数为 n 个,则选择排序的算法步骤如下:

  1. 初始状态下,无已排序区间,未排序区间为 [0,n−1]。
  2. 第 1 趟选择:
    1. 遍历未排序区间 [0,n−1],使用变量 min_i记录区间中值最小的元素位置。
    2. 将 min_i 与下标为 0 处的元素交换位置。如果下标为 0 处元素就是值最小的元素位置,则不用交换。
    3. 此时,[0,0] 为已排序区间,[1,n−1](总共 n−1 个元素)为未排序区间。
  3. 第 2 趟选择:
    1. 遍历未排序区间 [1,n−1],使用变量 min‾imin​i 记录区间中值最小的元素位置。
    2. 将 min‾i 与下标为 1 处的元素交换位置。如果下标为 1 处元素就是值最小的元素位置,则不用交换。
    3. 此时,[0,1] 为已排序区间,[2,n−1](总共 n−2个元素)为未排序区间。
  4. 依次类推,对剩余未排序区间重复上述选择过程,直到所有元素都划分到已排序区间,排序结束。

我们以 [5,2,3,6,1,4][5,2,3,6,1,4] 为例,演示一下选择排序的整个步骤。

 

选择排序代码实现 

class Solution:def selectionSort(self, nums: [int]) -> [int]:for i in range(len(nums) - 1):# 记录未排序区间中最小值的位置min_i = ifor j in range(i + 1, len(nums)):if nums[j] < nums[min_i]:min_i = j# 如果找到最小值的位置,将 i 位置上元素与最小值位置上的元素进行交换if i != min_i:nums[i], nums[min_i] = nums[min_i], nums[i]return numsdef sortArray(self, nums: [int]) -> [int]:return self.selectionSort(nums)

选择排序算法分析

时间复杂度:O(n*n)。排序法所进行的元素之间的比较次数与序列的原始状态无关,时间复杂度总是 O(n*n)。

  • 这是因为无论序列中元素的初始排列状态如何,第 i 趟排序要找出值最小元素都需要进行 n−i次元素之间的比较。因此,整个排序过程需要进行的元素之间的比较次数都相同,为 ​ 次。

空间复杂度:O(1)。选择排序算法为原地排序算法,只用到指针变量 i、j 以及最小值位置 min‾i 等常数项的变量。 

选择排序适用情况:选择排序方法在排序过程中需要移动较多次数的元素,并且排序时间效率比较低。因此,选择排序方法比较适合于参加排序序列的数据量较小的情况。选择排序的主要优点是仅需要原地操作无需占用其他空间就可以完成排序,因此在空间复杂度要求较高时,可以考虑选择排序。

排序稳定性:由于值最小元素与未排序区间第 11 个元素的交换动作是在不相邻的元素之间进行的,因此很有可能会改变相等元素的相对顺序,因此,选择排序法是一种 不稳定排序算法

http://www.xdnf.cn/news/1712.html

相关文章:

  • QT创建软件登录界面(14)
  • JavaScript 的“世界模型”:深入理解对象 (Objects)
  • 理解欧拉公式
  • 弄清C语言中的链表
  • 济南国网数字化培训班学习笔记-第二组-1节-输电线路工程
  • DRF凭什么更高效?Django原生API与DRF框架开发对比解析
  • 如何创建和使用 Hive 视图
  • 【低配置电脑预训练minimind的实践】
  • 【网络安全】社会工程学策略
  • H3C Magic路由器安全警报来啦![特殊字符][特殊字符]
  • Spark-Streaming核心编程(2)
  • 三国杀专业分析面板,立志成为桌游界的stockfish
  • AI与智能能源管理:如何通过AI优化能源分配和消耗?
  • 矩阵运营的限流问题本质上是平台与创作者之间的流量博弈
  • 【25软考网工】第三章(3)虚拟局域网VLAN
  • Nginx 反向代理,啥是“反向代理“啊,为啥叫“反向“代理?而不叫“正向”代理?它能干哈?
  • Qt5.15.2+OpenCV4.9.0开发环境搭建详细图文教程(OpenCV使用Qt自带MinGW编译的全过程,包教包会)
  • 低代码平台开发串口调试助手
  • 【Java面试笔记:进阶】17.一个线程两次调用start()方法会出现什么情况?
  • 单体OJ项目
  • Java语言的进化:JDK的未来版本
  • vue-study(1)
  • Vue3项目中 npm 依赖安装 --save 与 --save-dev 的区别解析
  • 面试篇:Spring Boot
  • leetcode 69和367
  • 一道MySQL索引题
  • 如何下载适用于语音识别功能增强的Google Chrome浏览器
  • JavaScript 页面刷新:从传统到现代的全面解析
  • 优雅实现网页弹窗提示功能:JavaScript与CSS完美结合
  • 网络原理 - 7(TCP - 4)