二路归并排序时间复杂度

 我来答
苍传真断0G
2023-02-01
知道答主
回答量:44
采纳率:50%
帮助的人:5750
展开全部

二路归并排序时间复杂度是O(nlogn)。

对于每一层来说,在合并所有子区间的过程中,n个元素都会被操作一次,所以每一层的时间复杂度都是O(n)。而之前说过,归并排序划分子区间,将子区间划分为只剩1个元素,需要划分logn次。每一层的时间复杂度为O(n),共有logn层,所以归并排序的时间复杂度就是O(nlogn)

归并排序是一种借助”归并“进行排序的方法。归并的含义是将两个或两个以上的有序序列归并为一个有序序列的过程。归并排序的主要思想是:将若干有序序列逐步归并,最终归并为一个有序序列。

其中最常见的是二路归并排序。二路归并排序是一种稳定的排序方法,其基本思想是:将若干个有序序列两两归并,直到形成一个有序序列为止。方法如下:将一个长度为n的无序序列看作是n个长度为1的有序序列的集合。然后两两归并,直到整个序列有序。

在归并的过程中,可能会破坏原序列的有序性,所以需要一个新的数组在存储归并后的结果。一次归并的算法是从开始同时遍历两个序列,将较小的值放入结果序列中,直到遍历结束,成为一个有序序列。

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式