我没有找到任何解决方案,如何简单地对原始数组进行排序。
我有更原始的数组:
public static String [] arr1={"name1","name2","name3"};
public static Double [] arr2={45.07,46.06,42.07};
public static Double [] arr3={183.95,192.94,182.94};
我唯一想做的就是根据arr3对数组进行排序,这样其他数据就会与arr3项保持相关。
例如。结果应该是:
1/ 182.94 name3 42.07
2/ 183.95 name1 45.07
3/ 192.94 name2 46.06
所以只需按arr3按升序对其进行排序,保留其他相关项。
我尝试了更多的解决方案,但没有效果。我也在这里找到了一些解决方案,但是没有解决方案可以同时使用更多数组,最大值为2。
如果我只用这个:
Arrays.sort(arr3);
然后它只会对arr3中的项进行排序,但其他数组中的其他项不适合。
然后我试着用这个:
Arrays.sort(arr1, new Comparator<Double>() {
public Double compare( Double o1, Double o2) {
return Double.compare(arr3[o1], arr3[o2]);
}
});
但是只有arr1并且还有一个错误,比较(Double,Double)在匿名类中与java.util.comparator中的Compare(T,T)冲突。试图使用不兼容的返回类型。
由于某种原因,返回类型需要int,而不是double。
您应该创建一个类来封装所述数据。避免创建并行数组,因为它们很难维护并且有时会出现问题。
因为所述数据是相关的,所以你应该为它创建一个模型,例如:
class ClassName { // I'll let you provide a more meaningful name
private String name;
private double latitude;
private double distance;
public String getName() {
return name;
}
public double getLatitude() {
return latitude;
}
public double getDistance() {
return distance;
}
public ClassName(String name, double latitude, double distance) {
this.name = name;
this.latitude = latitude;
this.distance = distance;
}
}
现在,然后旋转许多对象,你需要用必要的name
,latitude
和distance
填充它,然后将它存储到一个数组中,如下所示:
ClassName[] myArray = new ClassName[]{
new ClassName("name1",45.07, 183.95),
new ClassName("name2",46.06, 192.94)
};
然后按距离或任何其他属性排序变得如此简单:
Arrays.sort(myArray, new Comparator<ClassName>() {
@Override
public int compare(ClassName o1, ClassName o2) {
return Double.compare(o1.getDistance(), o2.getDistance());
}
);
然后,您可以根据需要向模型添加更多属性,而不必为混乱的并行阵列提供压力。