您的位置:首页 > 编程语言 > Java开发

关于Java中Arrays.sort()方法TLE

2016-06-10 02:39 603 查看
最近一直在练用Java写题,今天无意发现一道很简单的二分题(链接),我一开始是直接开int[]数组调用Arrays.sort()去排序,没想到TLE了,原来是因为jdk中对于int[]的排序是使用快速排序的,jdk中相关调用源码如下

public static void sort(Object[] a) {
if (LegacyMergeSort.userRequested)
legacyMergeSort(a);
else
ComparableTimSort.sort(a, 0, a.length, null, 0, 0);
}


View Code

或者也可以用List,然后调用Collections.sort()。

当然还可以先shuffle一下打乱数组,再调用排序,不过其实理论上来说还是有风险。

CF上有一篇博文可以参考:http://codeforces.com/blog/entry/7108

---------------------------------------------------------------------------------

6.20更新

今天我用Arrays.parallelSort方法测试了一下,发现在使用包装类数组Integer[]的情况下比正常的Arrays.sort慢,在使用基本类型int[]的情况下,同样超时,与预想结果不同,先记录下这个问题,暂时还没时间细究。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: