首页 Java java – 为什么使用两种不同的算法进行排序?

java – 为什么使用两种不同的算法进行排序?

在 Arrays类中,快速排序用于排序原语,但是对于排序对象,它是合并排序. 我想知道为什么会这样呢? 使用mergeesort的原因是他们想要一个稳定的算法 – 例如其中相等的对象(由compareTo()或compare())与以前相同的相对顺序. 对于原语,平等意味着“无区别”.当将{


Arrays类中,快速排序用于排序原语,但是对于排序对象,它是合并排序.

我想知道为什么会这样呢?

解决方法

使用mergeesort的原因是他们想要一个稳定的算法 – 例如其中相等的对象(由compareTo()或compare())与以前相同的相对顺序.

对于原语,平等意味着“无区别”.当将{5,3,5}分类到{3,5,5}时,以前是第一个.所以我们可以在这里使用更快(和非稳定的)快速排序算法.

本文来自网络,不代表青岛站长网立场。转载请注明出处: https://www.0532zz.com/html/kaifa/java/20201018/10999.html
上一篇
下一篇

作者: dawei

【声明】:青岛站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

为您推荐

返回顶部