版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 安全生产云演讲讲解
- 重点高校就业前景分析
- 医患关系现状深度反思
- 冷链隐患闭环管理实施指南
- 冷库隔油池运行监管细则
- 质检标准培训课件
- 消化内科医师质控年终总结
- 口腔科医师质控年终总结汇报
- 耳鼻喉科主任质控年终总结
- 过河北师大版三年级数学上册第一单元第3课时
- 2025内蒙古鄂尔多斯市委政法委所属事业单位引进高层次人才3人考试题库含答案解析(夺冠)
- 2025年全国单独招生考试综合试卷(附答案) 完整版2025
- 2025-2026学年外研版八年级上册英语期末模拟考试题(含答案)
- 洗衣液宣传课件
- “五个带头”方面对照发言材料二
- TTAF 241.1-2024 支持卫星通信的移动智能终端技术要求和测试方法 第1部分:多模天通卫星终端
- 奶茶品牌2026年新品研发上市流程
- 日常饮食营养搭配
- 上海医疗收费目录
- 国家义务教育质量监测体育体系
- 2025年中考数学压轴训练:一次函数综合题 (学生版)
评论
0/150
提交评论