java Arrays.sort 二维数组

新手上路,请多包涵

我希望根据 [][0] 的值对以下数组进行排序

double[][] myArr = new double[mySize][2];

例如,myArr 内容是:

 1      5
13     1.55
12     100.6
12.1   .85

我希望它达到:

 1      5
12     100.6
12.1   .85
13     1.55

我希望在不必实现自己的排序的情况下做到这一点。

原文由 Dax Durax 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 645
2 个回答

使用 Overloaded Arrays#Sort(T[] a, Comparator c) ,它将 Comparator 作为第二个参数。

 double[][] array= {
{1, 5},
{13, 1.55},
{12, 100.6},
{12.1, .85} };

java.util.Arrays.sort(array, new java.util.Comparator<double[]>() {
    public int compare(double[] a, double[] b) {
        return Double.compare(a[0], b[0]);
    }
});

JAVA-8: 我们可以使用 lambda 函数来代替那个大比较器,如下所示-

 Arrays.sort(array, Comparator.comparingDouble(o -> o[0]));

原文由 PermGenError 发布,翻译遵循 CC BY-SA 4.0 许可协议

欢迎 Java 8:

 Arrays.sort(myArr, (a, b) -> Double.compare(a[0], b[0]));

原文由 Marsellus Wallace 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题