加入收藏 | 设为首页 | 会员中心 | 我要投稿 哈尔滨站长网 (https://www.0451zz.com/)- 数据分析、智能存储、视频终端、云渲染、网络安全!
当前位置: 首页 > 编程开发 > Java > 正文

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

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

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

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

解决方法

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

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

(编辑:哈尔滨站长网)

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

    推荐文章
      热点阅读