- 1、本文档共19页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
**********关于直接插入排序教学内容:1、排序的基本概念2、直接插入排序算法的基本思想3、直接插入排序算法实现4、直接插入排序算法性能分析教学重点:直接插入排序算法思想教学难点:算法实现及性能分析教学过程第2页,共19页,星期六,2024年,5月第3页,共19页,星期六,2024年,5月学号姓名学习成绩思想政治总分奖学金等次1008XXX2622929111005XXX2502927921003XXX2492827721002XXX2482827621006XXX2432827131007XXX2422726931001XXX2312725831004XXX211272383………………第4页,共19页,星期六,2024年,5月8.2.1排序概念排序无序数据有序数据排序算法主要有:直接插入排序、希尔排序、冒泡排序、快速排序、直接选择排序、堆排序、归并排序等。第5页,共19页,星期六,2024年,5月8.2.2直接插入排序基本思想212549361608i…n-1数组下标数组R有序区无序区13无序区第1个元素……0…i-1第6页,共19页,星期六,2024年,5月如何确定插入位置?关键问题第7页,共19页,星期六,2024年,5月212549360813排序过程临时变量temp16543201…n-1下标…第8页,共19页,星期六,2024年,5月流程图(tempR[j])(j=0)开始temp=R[i]j=i-1循环判断R[j+1]=R[j]j--R[j]=tempNY结束将无序区中的第一个元素放到临时变量中j表示有序区中的最后一个元素的位置将当前元素向后移动有序区中比较下一个找到插入位置后将第1个元素插入第9页,共19页,星期六,2024年,5月8.2.3算法实现for(i=1;in;i++){//插入所有元素Voidinsertsort(arrayTypeR[],intn){inti,j,temp;temp=R[i];//将待排序元素放入临时变量while((tempR[j])(j=0)){R[j+1]=R[j];//元素向后移动j--;//向左继续查找}R[j+1]=temp;//将元素插入相应位置}j=i-1;//从R[i-1]开始向左查找}第10页,共19页,星期六,2024年,5月评价排序算法好坏的标准:一、时间复杂度-算法执行所需要的时间(比较次数和移动次数)二、空间复杂度-算法执行所需要的辅助空间个数主要考虑次要考虑第11页,共19页,星期六,2024年,5月for(i=1;in;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(tempR[j])(j=0)R[0]R[j]浪费时间第12页,共19页,星期六,2024年,5月第一进入循环之前,保存R[i]的值第二在while循环中“监视”下标是否越界。监视哨使用R[0]的意义第13页,共19页,星期六,2024年,5月8.2.3改进后算法insertsort(R){inti,j;for(;in;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第14页,共19页,星期六,2024年,5月8.2.4性能分析212549361608131、理想情况第15页,共19页,星期六,2024年,5月2、最坏情况212549361
文档评论(0)