《数据结构用C语言描述》第八章j.pptxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

概述插入排序交换排序选择排序归并排序基数排序各种内排方法比较第八章排序

概述1排序:将一个数据元素的任意序列,重新排列成一个按关键字有序的序列。数据表(datalist):它是待排序数据对象的有限集合。主关键字(key):数据对象有多个属性域,即多个数据成员组成,其中有一个属性域可用来区分对象,作为排序依据,称为关键字。也称为关键字。2

排序方法的稳定性:如果在对象序列中有两个对象r[i]和r[j],它们的关键字k[i]==k[j],且在排序之前,对象r[i]排在r[j]前面。如果在排序之后,对象r[i]仍在对象r[j]的前面,则称这个排序方法是稳定的,否则称这个排序方法是不稳定的。01内排序与外排序:内排序是指在排序期间数据对象全部存放在内存的排序;外排序是指在排序期间全部对象个数太多,不能同时存放在内存,必须根据排序过程的要求,不断在内、外存之间移动的排序。02

排序的时间开销:排序的时间开销是衡量算法好坏的最重要的标志。排序的时间开销可用算法执行中的数据比较次数与数据移动次数来衡量。typedefstruct{intkey;datatypeother;}rectype;rectypeR[n];

02依不同原则插入排序、交换排序、选择排序、归并排序、和基数排序等。依所须工作量简单排序---时间复杂度o(n2)先进排序方法---时间复杂度o(nlogn)基数排序---时间复杂度o(d.n)01内排序分类

基本思想当插入第i(i?1)个对象时,前面的R[0],R[1],…,R[i-1]已经排好序。这时,用R[i]的关键字与R[i-1],R[i-2],…的关键字顺序进行比较,找到插入位置即将R[i]插入,原来位置上的对象向后顺移。1基本思想每步将一个待排序的对象,按其关键字大小,插入到前面已经排好序的一组对象的适当位置上,直到对象全部插入为止。2直接插入排序(InsertSort)3插入排序(InsertSorting)

直接插入排序过程012345tempi=1i=2012345temp2108254925*162125084925*16252125084925*162125084925*16492125084925*16i=32125084925*1625*2125084925*16

i=4i=52125084925*1616162125084925*162125084925*162125084925*1608

直接插入排序的算法InsertSort(rectypeR[],intn){inti,j;for(i=2;in;i++){R[0]=R[i];j=i–1;//从后向前顺序比较while(R[0].keyR[j].key)R[j+1]=R[j--];R[j+1]=R[0];}}

设待排序对象个数为n,则该算法的主程序执行n-1趟。01关键字比较次数和对象移动次数与对象关键字的初始排列有关。02最好情况下,排序前对象已按关键字从小到大有序,每趟只需与前面有序对象序列的最后一个对象比较1次,移动2次对象,总的关键字比较次数为n-1,对象移动次数为2(n-1)。03算法分析

最坏情况下,第i趟时第i个对象必须与前面i个对象都做关键字比较,并且每做1次比较就要做1次数据移动。则总关键字比较次数KCN和对象移动次数RMN分别为在平均情况下的关键字比较次数和对象移动次数约为n2/4。因此,直接插入排序的时间复杂度为o(n2)。直接插入排序是一种稳定的排序方法。010203

基本思想设在顺序表中有一个对象序列R[0],R[1],…,R[n-1]。其中,R[0],R[1],…,R[i-1]是已经排好序的对象。在插入R[i]时,利用折半搜索法寻找R[i]的插入位置。01折半插入排序的算法02折半插入排序(BinaryInsertsort)

typedefintSortData;RoidBinInsSort(SortDataR[],intn){SortDatatemp

文档评论(0)

wuyoujun92 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档