




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
直接插入排序第一页,共18页。教学内容:
1、排序的基本概念
2、直接插入排序算法的基本思想
3、直接插入排序算法实现
4、直接插入排序算法性能分析教学重点:直接插入排序算法思想
教学难点:算法实现及性能分析
教学过程
第二页,共18页。第三页,共18页。学号姓名学习成绩思想政治总分奖学金等次1008XXX2622929111005XXX2502927921003XXX2492827721002XXX2482827621006XXX2432827131007XXX2422726931001XXX2312725831004XXX211272383………………第四页,共18页。8.2.1排序概念排序无序数据有序数据排序算法主要有:直接插入排序、希尔排序、冒泡排序、快速排序、直接选择排序、堆排序、归并排序等。第五页,共18页。8.2.2直接插入排序基本思想212549361608i…n-1数组下标数组R有序区无序区13无序区第1个元素……0…
i-1第六页,共18页。如何确定插入位置?关键问题第七页,共18页。212549360813排序过程临时变量temp16543201…n-1下标…第八页,共18页。流程图(temp<R[j])&&(j>=0)开始temp=R[i]j=i-1循环判断R[j+1]=R[j]j--R[j]=tempNY结束将无序区中的第一个元素放到临时变量中j表示有序区中的最后一个元素的位置将当前元素向后移动有序区中比较下一个找到插入位置后将第1个元素插入第九页,共18页。8.2.3算法实现for(i=1;i<n;i++){//插入所有元素Voidinsertsort(arrayTypeR[],intn){inti,j,temp;temp=R[i];//将待排序元素放入临时变量while((temp<R[j])&&(j>=0)){R[j+1]=R[j];//元素向后移动j--;//向左继续查找
}R[j+1]=temp;//将元素插入相应位置
}j=i-1;//从R[i-1]开始向左查找}第十页,共18页。评价排序算法好坏的标准:一、时间复杂度-算法执行所需要的时间(比较次数和移动次数)二、空间复杂度-算法执行所需要的辅助空间个数主要考虑次要考虑第十一页,共18页。for(i=1;i<n;i++){Voidinsertsort(arrayTypeR[],intn){inti,j,temp;tempWhile(
){R[j+1]=R[j];j--;}R[j+1]=;}j=i-1;}=R[i];R[0]2R[0]temp(temp<R[j])&&(j>=0)R[0]<R[j]浪费时间第十二页,共18页。第一进入循环之前,保存R[i]的值第二在while循环中“监视”下标是否越界。监视哨使用R[0]的意义第十三页,共18页。8.2.3改进后算法insertsort(R){inti,j;for(;i<n;i++){
j=i-1;
{R[j+1]=R[j];j--;}
;}}
R[0]=R[i];while(R[0]<R[j])R[j+1]=R[0]i=2第十四页,共18页。8.2.4性能分析212549361608131、理想情况第十五页,共18页。2、最坏情况21254
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论