在单个数组上按ArrayList索引(行)排序三个数组

时间:2015-04-03 09:56:14

标签: java arrays sorting arraylist collections

在ArrayList中,我有三个double []数组,我希望在第三个数组上排序。第三个数组也是未排序的。

public class LevelList extends ArrayList<double[]> {

我的比较器compares doubles

import java.util.Comparator;

public class Linearize {
     static final Comparator<double[]> RATIO_ORDER = 
             new Comparator<double[]>() {
                 @Override
                 public int compare(double[] d1, double[] d2) {
                     //Sort the ratios based on the fraction column 2
                     return Double.compare(d1[2], d2[2]);
                 }
         };
}
然后我打电话给:

Collections.sort(levelList, Linearize.RATIO_ORDER);
levelList.println();

但是,这只会导致对ArrayList中数组顺序的排序。

在伪代码中,我希望实现的目标是:

For Each Row of ArrayList at Index i
Sort on Array 3

这样输入:

[1.0][2.0][2.1]
[2.0][5.0][2.2]
[1.0][5.0][1.0]

变为:

[1.0][5.0][1.0]
[1.0][2.0][2.1]
[2.0][5.0][2.2]

因为:2.2&gt; 2.1&gt; 1.0

1 个答案:

答案 0 :(得分:1)

我得到了所需的输出。我测试了以下代码。不明白为什么levellist必须扩展arraylist,因此删除了。

public class TestLevelSorting {
public static void main(String[] args) {

    List<double[]> levelList = new ArrayList<double[]>();

    double[] items1 = {1.0, 2.01, 2.1};
    double[] items2 = {2.0, 5.0, 2.2};
    double[] items3 = {1.0, 5.0, 1.0};

    levelList.add(items1);
    levelList.add(items2);
    levelList.add(items3);

    Collections.sort(levelList, Linearize.RATIO_ORDER);

    for(double[] item : levelList){
        System.out.println(Arrays.toString(item));
    }
}
}

class Linearize {
static final Comparator<double[]> RATIO_ORDER = new Comparator<double[]>() {
    @Override
    public int compare(double[] d1, double[] d2) {
        // Sort the ratios based on the fraction column 2
        return Double.compare(d1[2], d2[2]);
    }
};
}