关于合并排序代码中的合并步骤的混淆

编程入门 行业动态 更新时间:2024-10-27 02:26:22
本文介绍了关于合并排序代码中的合并步骤的混淆的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧! 问题描述

我有一个关于数组合并排序如何工作的问题。 我理解‘Divide’步骤,它将一个输入数组分成1个长度的元素。然而,当谈到‘合并’部分(合并步骤)时,我就糊涂了。 例如,给定输入3 5 1 8 2,除法过程将产生5个元素:3,5,1,8,2。我只了解合并函数会将它们组合为3 5,1 8,2,但它如何继续组合3 5和1 8?‘Combine’部分中是否涉及递归?

推荐答案

当两个递归排序例程返回时,您可以安全地假定它们已经对其各部分进行了排序。合并步骤组合这两个排序的子数组。如果输入为3 5 1 8 2,则第一个递归调用对前半部分进行排序并生成3 5,第二个递归调用对后半部分进行排序并生成1 2 8。

您询问的合并步骤,通过重复选择两个子数组的前两个元素中的最小值并将其添加到结果中,将这两个排序的一半合并为一个,如下面的动画所示:

更多推荐

关于合并排序代码中的合并步骤的混淆

本文发布于:2023-11-30 17:07:16,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1650818.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:步骤   代码

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!