- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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){对左子序列和右子序列归并排序}
您可能关注的文档
最近下载
- 中国山水画中的道家美学.doc VIP
- 人文关怀的护理课件最新完整版本.pptx VIP
- 基于Unity3D C#语言的防范疫情的游戏设计与制作.doc VIP
- 部编版七年级语文上册、下册全册教案(全册教学设计).docx VIP
- 智能电气设计EPLAN 第2版 课件 项目五 任务三 热过载继电器部件制作.pptx
- 梅特勒pH计FE28说明书.pdf VIP
- 第四纪地质与地貌学_第三章_第四纪基本问题_3-第四纪气候分解.ppt
- 江苏省南京市2024-2025学年高一下学期6月期末考试语文试题(含答案).doc VIP
- 《中等数学增刊1-2018》.doc VIP
- 银行利率定价管理委员会工作制度.docx
文档评论(0)