加入收藏 | 设为首页 | 会员中心 | 我要投稿 甘南站长网 (https://www.0941zz.com/)- 科技、行业物联网、开发、云计算、云管理!
当前位置: 首页 > 编程开发 > Java > 正文

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

发布时间:2020-11-17 14:31:56 所属栏目:Java 来源:互联网
导读:在 Arrays类中,快速排序用于排序原语,但是对于排序对象,它是合并排序. 我想知道为什么会这样呢? 使用mergeesort的原因是他们想要一个稳定的算法 – 例如其中相等的对象(由compareTo()或compare())与以前相同的相对顺序. 对于原语,平等意味着“无区别”.当将{

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

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

解决方法

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

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

(编辑:甘南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读