加入收藏 | 设为首页 | 会员中心 | 我要投稿 4S站长网 (https://www.4s3.cn/)- 科技、混合云存储、数据迁移、云上网络、数据计算!
当前位置: 首页 > 编程开发 > Java > 正文

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

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

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

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

解决方法

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

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

(编辑:4S站长网)

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

    推荐文章
      热点阅读