培训学案算法排序归并.pdfVIP

  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文档。上传文档
查看更多

归并排序

某数列在对序列A[1],A[2],……,A[n],现采用归并思想进行排序。

分析:

这里我们采用二分法。先将n个元素分成两个各含n/2或(n/2)个元素的子序列;



再用归并排序法对两个子序列递归的排序;最后合并两个已排序的子序列以得到排序结果。

在对子序列排序时,当其长度为1时递归结束。单个元素被视为是已经排好的序列。

下面我们来分析一下对两个已排好序的子序列A[P..Q]和A[Q+1..R],将它们合并成

一个已排好的子序列[P..R]。

引入一个辅助过程merge(A,P,Q,R)来完成这一合并工作,其中A是数组,P,Q,R

是下标。其方法是:每次选两个子序列中较小的一个元素加入到目标序列中,直到某一个子

序列为空,最后把另一子序列中剩下的元素加入到目标序列中。

procedureMerge(varA:ListType;P,Q,R:Integer);

{将A[P..Q]和A[Q+1..R],合并到序列A[P..R]}

var

I,{左子序列指针}

J,{右子序列指针}

T:Integer;{合并后的序列的指针}

Lt:ListType;{暂存合并的序列}

begin

T:=P;I:=P;J:=Q+1;

whileT=Rdobegin{合并未完成}

{若左序列剩有元素并且右序列元素全部合并或

左序列的首元素小于等于右序列的首元素,则左序列的首元素进入合并序列}

if(I=Q)and((JR)or(A[I]=A[J]))thenbegin

Lt[t]:=A[I];Inc(I);

end

elsebegin{否则右序列的首元素进入合并序列}

Lt[t]:=A[J];Inc(J);

end;

Inc(T);{合并后的序列的指针右移}

end;

A:=Lt;{合并后的序列赋给A}

end;

下面我们来看看分治过程。利用merge_sort(A,P,R)对数组A[P..R]进行排序。若

P=R,则子序列只有一个元素,分解完毕。否则,计算出中间下标Q,将A[P..R]分成A[P..Q]

和A[Q+1..R]。若数组A[P..R]的元素个数K=R-P+1为偶数,则两个数组各含K/2个元素;

否则A[P..Q]含k/2个元素,A[Q+1..R]含k/2个元素。



procedureMerge_Sort(varA:ListType;P,R:Integer);

var

Q:Integer;

begin

ifPRthenbegin{若子序列A中不止一个元素}

Q:=(P+R-1)div2;{计算中间下标Q}

Merge_Sort(A,P,Q);{继续对左子序列A[P..Q]递归排序}

Merge_Sort(A,Q+1,R);{继续对左子序列A[Q+1..R]递归排序}

Merge(A,P,Q,R){对左子序列和右子序列归并排序}

文档评论(0)

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

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

版权声明书
用户编号:8001056127000014

1亿VIP精品文档

相关文档