首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >这是选择排序还是插入排序?

这是选择排序还是插入排序?
EN

Stack Overflow用户
提问于 2015-05-09 03:40:44
回答 4查看 1.7K关注 0票数 0

假设我们使用二次排序算法对一个由十个整数组成的数组排序。在对算法的主循环进行四次迭代之后,排列数组元素如下所示:

1 2 3 4 5 0 6 7 8 9

哪条语句是正确的?(注意:我们的选择排序首先选择最大的项目。)

A.算法可以是选择排序,也可以是插入排序。

B。算法可能是选择排序,但不能是插入排序。

C.算法可能是插入排序,但不能选择排序。

D算法既不是选择排序,也不是插入排序。

我认为答案应该是A(插入排序和选择排序)?但我在一些网站上发现正确答案是C。我不知道原因。谁能解释一下。

如果我错了,请纠正我。

来源:谷歌图书

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2015-05-09 03:53:37

这种输出对于最大的优先选择排序是可能的。

它不能是最小优先选择排序,因为选择排序保持不变,在n次迭代后,列表中的前n项是完全排序的。因此,如果这是一种选择排序,您将期望值为0的元素在第一次迭代中被排序为索引0。因此,在前4次迭代之后,列表将类似于0 1 2 3 ...

由于插入排序具有不同的不变量,所以最大先插入排序和最小插入排序都可以输出。在插入排序中,经过n次迭代后,列表中的前n项(最后n项表示最大的第一次排序)是按彼此排序的,但它们不一定在列表中的最后位置。

对于最小的第一个插入排序,经过4次迭代之后,就可以看到“of”0,因为排序还没有迭代到在其正确的索引中重新定位0。

票数 0
EN

Stack Overflow用户

发布于 2015-05-09 03:51:07

插入排序是可能的,因为当前快照刚刚完成从索引0到4的数组排序。

选择排序将首先选择最小值(在示例中为0),并将其放在左侧。所以答案是C。

票数 0
EN

Stack Overflow用户

发布于 2015-05-09 03:56:01

这可以是最大优先选择排序或插入排序的输出。如果数组最初的样子是这样的,经过两种算法的4次迭代后,它仍然是这样的。它不可能是最小的优先选择排序,因为经过4次迭代之后,数组的前4项将是0 1 2 3

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30135705

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档