




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
5.5数据排序–选择排序(升序为例)《数据与数据结构》一、选择排序基本思想:是对参加排序的数组中所有元素中找出最小(或最大)的数据,使它与第一个(或最后一个)元素中的数据进行相互交换位置。然后在余下的元素中找出最小(或最大)的数据,与第二个(或最后第二个)元素中的数据交换位置。以此类推,直到所有元素称为一个有序的序列。一、选择排序过程每趟排序后数组a的值分别为:第1趟:[1,9,3,8,5,2]第2趟:[1,2,3,8,5,9]第3趟:[1,2,3,8,5,9]第4趟:[1,2,3,5,8,9]第5趟:[1,2,3,5,8,9]一、选择排序过程注意:红色标记最小值
绿色标记待排序区间
黄色标记有序区间三、选择排序和冒泡排序
对比小结冒泡排序选择排序排序遍数比较次数交换次数时间复杂度n-1n-1(n-1)*n/2(n-1)*n/2逆序对数量<=n-1O(n2)O(n2)选择排序的比较次数与待排序元素的初始状态无关,而交换次数与待排序元素的初始状态有关,当待排序元素已经有序时,交换
0次,最坏情况下交换n-1次。一、选择排序程序实现(以升序为例)i=0;min=?forjinrange(1,?)#依次比较找最小值的下标ifa[j]
?
a[min]:#升序排序min=jifmin!=?:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值i=0;min=0forjinrange(1,6)#依次比较找最小值的下标ifa[j]
<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值一、选择排序程序实现(以升序为例)i=1;min=?#假设待排序区间第一个元素为擂主forjinrange(?,?)#依次比较找最小值的下标ifa[j]
?
a[min]:#升序排序min=jifmin!=?:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值i=1;min=1#假设待排序区间第一个元素为擂主forjinrange(2,6)#依次比较找最小值的下标ifa[j]
<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值一、选择排序程序实现(以升序为例)i=2;min=?forjinrange(?,?)#依次比较找最小值的下标ifa[j]
<
a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值i=2;min=2forjinrange(3,6)#依次比较找最小值的下标ifa[j]
<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值一、选择排序程序实现(以升序为例)i=3;min=?forjinrange(?,?)#依次比较找最小值的下标ifa[j]
<
a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值i=3;min=3forjinrange(4,6)#依次比较找最小值的下标ifa[j]
<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值一、选择排序程序实现(以升序为例)i=4;min=?forjinrange(?,?)#依次比较找最小值的下标ifa[j]
<
a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值i=4;min=4forjinrange(5,6)#依次比较找最小值的下标ifa[j]
<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值一、选择排序程序实现(6个元素升序为例)i=0;min=0#第一趟排序forjinrange(1,6)#依次比较找最小值的下标ifa[j]
<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值i=1;min=1#第二趟排序forjinrange(2,6)#依次比较找最小值的下标ifa[j]
<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值i=2;min=2#第三趟排序forjinrange(3,6)#依次比较找最小值的下标ifa[j]
<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值i=3;min=3#第四趟排序forjinrange(4,6)#依次比较找最小值的下标ifa[j]
<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值i=4;min=?#第五趟排序forjinrange(5,6)#依次比较找最小值的下标ifa[j]
<
a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]
#交换a[min]与a[i]的值n=len(a)
#n个元素规模升序排序
做个笔记宝典P82foriinrange(?)#外循环表示排序趟次
min=?#假设待排序区间第一个元素为擂主
forjinrange(?,?):#将每个元素跟当前擂主PK
ifa[j]
?
a[min]:#PK成功则更换擂主min=j
#更换擂主ifmin!=i
:a[min],a[i]=a[i],a[min]
#交换n-1ii+1n<二、选择排序和冒泡排序
程序对比小结n=len(a)
#选择排序
顺序扫描foriinrange(n-1)#排序最多n-1趟
min=i#假设待排序区间第一个元素为擂主
forjinrange(i+1,n):#将每个元素跟当前擂主PK
ifa[j]
<
a[min]:#PK成功则更换擂主
升序
min=j
#更换擂主ifmin!=i
:
a[min],a[i]=a[i],a[min]
#交换n=len(a)#冒泡排序
逆序扫描foriinrange(n-1):#排序n-1趟
forjinrange(n-1,i,-1):#从后往前扫描ifa[j-1]>a[j]:#相邻元素比较
升序
a[j],a[j-1]=a[j-1],a[j]#交换选择与冒泡排序的最大区别:选择排序待排序区间内的元素a[min]能与最左端(或最右端)的元素a[i]发生交换,冒泡排序是相邻元素交换。对比两段程序,为何选择排序更高效,主要就是因为有min变
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 全县舆情调研报告范文
- 清明实践报告范文
- 2025年度木材代理进口合同模板(含检疫标准)
- 2025年度足疗养生馆连锁经营权及商标转让合同书
- 二零二五年度学生安全保障与家长责任书
- 2025年度电力安全监督电力安装工程劳务分包协议
- 二零二五年度智慧物流项目预算执行书
- 二零二五年度手摩托线上线下销售渠道合作合同
- 2025年度旅游咨询兼职合同
- 槟榔品牌2025年度线上线下联合代理协议
- 2024年科技节小学科普知识竞赛题及答案(共100题)
- 2025年度教育培训机构学生综合素质评价协议3篇
- 国网工程项目管理制度
- 氧气管道吹扫、打压方案
- 第28课 改革开放和社会主义现代化建设的巨大成就 教学设计(表格式)必修 中外历史纲要(上)
- 追觅科技28题在线测试
- 中庸之道课件
- office办公软件应用教学教案150
- 风力发电厂土建工程施工组织设计
- GB/T 44811-2024物联网数据质量评价方法
- 高速公路改建拆除施工方案
评论
0/150
提交评论