排序算法:【选择排序]

一、选择排序——时间复杂度O(n^{2})

定义:第一趟排序,从整个序列中找到最小的数,把它放到序列的第一个位置上,第二趟排序,再从无序区找到最小的数,把它放到序列的第二个位置上,以此类推。

        也就是说,首先从序列中找到最小的元素,放到有序区的第一个位置上,然后再从剩下的无序区中,继续找最小的元素,放到有序区的末尾。

1、容易想到的方法——不推荐

        新建一个空列表,然后每遍历一次老列表时候,就把一个最小值,放到新列表里,同时再把这个值从老列表里删除掉。

但这种方法有两个缺点:

(1)额外占内存。因为新建了一个空列表 l1,所以就会多占用一个内存空间。

(2)时间复杂度高,排序效率慢。

        列表的增加和删除方法,时间复杂度都是O(n)。

        原因:把最小值加到新列表里,首先要先找到最小值,而找最小值的过程,其实就是把所有值都遍历一遍,所以,增加的操作,时间复杂度式O(n)。

        同理,对于删除操作也一样,你要删掉最小值,首先得找到,而找最小值的过程就是要把列表全部遍历一遍,时间复杂度也是O(n)。

        所以,法1中,增加和删除操作,它俩时间复杂度其实也就是O(n)+O(n),因为他俩是并行运行的,不是嵌套运行,所以结果还是O(n)。外面还有一个for循环,所以法1代码,复杂度就是O(n^{2})

# 法1
def select_sort_simple(li):  l1 = []for i in range(len(li)):  # 时间复杂度o(n)l1.append(min(li))   li.remove(min(li)) return l1result = select_sort_simple([5, 3, 7, 2, 4])
print(result)# 结果:
[2, 3, 4, 5, 7]

        或许你会说,把最小值,赋值给一个变量,比如,a=min(li),然后每次增加删除这个值,结果还一样吗?答案是肯定一样的,因为,你即使把它赋值给一个变量,但前提,你也得先找到这个最小值,而找最小值的过程就是把列表所有值都遍历一遍,此时它的复杂度就已经是O(n)了,再加上外面的for循环,代码整体复杂度还是O(n^{2})

# 法2 最小值,赋值给一个变量
def select_sort_simple(li):  l1 = []for i in range(len(li)):  # 时间复杂度 O(n)a=min(li)   # 时间复杂度 O(n)l1.append(a)   li.remove(a)  return l1result = select_sort_simple([5, 3, 7, 2, 4])
print(result)
# 结果同上

2、使用切片的方式控制无序区——推荐

        使用切片的方式控制无序区,每一趟排序后,都将无序区中的最小值,放到无序区的第一个位置,也就是说,把无序区的最小值跟无序区的第一个元素进行交换,此时,这个最小值也就自然放到了有序区的末尾。

跟上面方法相比,虽然时间复杂度一样,但是不用新建空列表。

# 推荐!!!
def select_sort(li): for i in range(len(li) - 1):  # 总共要排n-1趟min_val = min(li[i:])  # !!! 每遍历一次,无序区就会少一个数a = li.index(min_val)  # 找到最小值的下标li[i], li[a] = li[a], li[i]  # 每趟遍历,就把最小值与这趟对应位置上的数进行交换# 或者说,就是把无序区的最小值与无序区第一个数进行交换return liresult = select_sort([5, 1, 2, 4])
print(result)
# 结果:
[1, 2, 4, 5]

效果图: 

当然也可以输出每趟排序的结果,结果跟上图也是一样的:

def select_sort(li):for i in range(len(li) - 1):  # 总共要排n-1趟min_val = min(li[i:])  a = li.index(min_val)  # 找到最小值的下标li[i], li[a] = li[a], li[i] print(li)  # !!每趟排序后的结果return liresult = select_sort([5, 1, 2, 4])
print("最终排序结果", result)# 结果:
[1, 5, 2, 4]
[1, 2, 5, 4]
[1, 2, 4, 5]
最终排序结果 [1, 2, 4, 5]

面方法中,使用的是切片来控制无序区的大小,(或者叫范围),然后再从这个范围里找最小值,这里呢,我们也可以使用 for 循环的形式来控制无序区的范围。代码如下:

这个跟上面方法类似,但利用切片方式控制无序区范围,相比for循环会更加简洁明了,所以推荐切片的方法。

def select_sort(li):for i in range(len(li) - 1):  # 总共要排n-1趟min_loc = i  # 假设无序区的第一个数是最小数for j in range(i+1, len(li)):  # 遍历无序区if li[j] < li[min_loc]:  # 如果无序区中,有个数比无序区第一个数小min_loc = j  # 改变最小值的下标li[i], li[min_loc] = li[min_loc], li[i]  # 将无序区第一个数与最小数进行交换print(li)  # 每趟排序后的结果return li# result = select_sort([3, 4, 2, 1, 5, 6, 8, 7, 9])
result = select_sort([5, 1, 2, 4])
print("最终排序结果", result)# 结果:
[1, 5, 2, 4]
[1, 2, 5, 4]
[1, 2, 4, 5]
最终排序结果 [1, 2, 4, 5]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/266595.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【特殊文件(一)】属性文件读写实操

文章目录 属性文件特殊文件概述Properties属性文件概述Properties属性文件读取Properties属性文件写操作 属性文件 特殊文件概述 IO流是用来读、写文件中的数据。但是我们接触到的文件大部分都是普通的文本文件&#xff0c;普通的文本文件里面的数据是没有任何格式规范的&…

基于SSM的校园二手物品交易平台论文

毕 业 设 计&#xff08;论 文&#xff09;题目&#xff1a;校园二手物品交易平台设计与实现 摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本校园二手物品…

5. Jetson Orin Nano CUDA 配置

5. Jetson Orin Nano CUDA 配置 1&#xff1a;安装Jtop jtop安装主要有以下三个步骤&#xff1a; 安装pip3 我们需要使用pip3来安装jtop&#xff0c;所以先安装pip3 sudo apt install python3-pip安装jtop sudo -H pip3 install -U jetson-stats运行jtop服务 sudo -H pip3 in…

高级网工在Linux服务器抓包,少不了这几条常用的tcpdump命令。

Linux 的命令太多&#xff0c;tcpdump 是一个非常强大的抓包命令。有时候想看线上发生的一些问题&#xff1a; nginx 有没有客户端连接过来…… 客户端连接过来的时候 Post 上来的数据对不对…… 我的 Redis 实例到底是哪些业务在使用…… tcpdump 作为网络分析神器就派上用场…

SpringData JPA 搭建 xml的 配置方式

1.导入版本管理依赖 到父项目里 <dependencyManagement><dependencies><dependency><groupId>org.springframework.data</groupId><artifactId>spring-data-bom</artifactId><version>2021.1.10</version><scope>…

fastdds共享内存实现原理

fastdds 共享内存分两个部分&#xff0c;一部分用于保存数据&#xff0c;一部分用于通信。 fastrtps_“UUID”:共享内存包括又两部分数据&#xff0c;BufferNode和segment_size, 用配置文件port_queue_capacity_指定BufferNode的数量&#xff0c;segment_size用于保存实际传输的…

互联网寒冬,抱团取暖!软件测试十大必问面试题(附答案和解析)

01 介绍之前负责的项目 参考答案&#xff1a;先大概描述一下这个项目是做什么的&#xff08;主要功能&#xff09;&#xff0c;包括哪些模块&#xff0c;是什么架构的&#xff08;B/S、C/S、移动端&#xff1f;&#xff09;&#xff0c;你在其中负责哪些模块的测试。期间经历了…

moviepy基本参数用法大全

阅读本文档的前置说明&#xff1a; 本文档用于讲解Python的moviepy库的自带函数的用法&#xff0c;主要目的是讲一下每个函数的每个参数的含义&#xff0c;无需一开始就全部掌握&#xff0c;粗略看一下就行&#xff0c;可以在后面自己开发过程&#xff0c;遇到不会用的函数再回…

开关量防抖滤波器(梯形图和SCL源代码)

模拟量防抖超限报警功能块请查看下面文章链接: https://rxxw-control.blog.csdn.net/article/details/133969425https://rxxw-control.blog.csdn.net/article/details/133969425 1、开关量防抖滤波器 2、防抖滤波 3、梯形图代码

避碰规则_避碰与信号

第一章 总则 第二章 航行和避让 第一节 行动通则 第二节 机动船相遇&#xff0c;存在碰撞危险时的避让行动 第三节 机动船、人力船、帆船、排筏相遇&#xff0c;存在碰撞危险时的避让行动 第四节 船舶在能见度不良时的行动及其他 第三章 号灯和号型 1

【C++11】lambda表达式及包装器

一.lambda表达式 1.可调用对象 可调用对象即可以像函数一样被调用的对象&#xff0c;有以下三种&#xff1a; 函数(指针)仿函数对象lambda表达式 tips&#xff1a;调用函数时&#xff0c;既可以用函数名&#xff0c;也可以用函数地址&#xff0c;因为函数名和函数地址是一回事…

xtts和ogg不选择?

不选择ogg的理由&#xff1a; 1.需要在源端创建用户赋权&#xff0c;启用数据库最小日志&#xff0c;附加日志等操作--对生产影响较大 2.外键约束过多&#xff0c;割接启用可能很慢https://www.modb.pro/db/201126--割接停机时间影响 3.初始化配置expdp导出可能快照过旧&#x…