最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

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

SEO心得admin69浏览0评论
本文介绍了关于合并排序代码中的合并步骤的混淆的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧! 问题描述

我有一个关于数组合并排序如何工作的问题。 我理解‘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。

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

发布评论

评论列表(0)

  1. 暂无评论