最近小编,在积极备战秋招大战,在编程题方面,许多题目用到了排序,都用到 java.util.Comparator 比较器,特别是在有的地方需要对二维数组排序
说重点
但是在比较时,只能将二维数组的一列,作为条件比较,比如你的数组是 int arr[][] = new int [3][2],不能同时将数组的两列作为条件判断,发现可以依据判断条件,可以同时判断二维数组的两列,这在以后工作学习中,会方便很多。
上代码
现在你的输入循序是这样
aaa aaa
aaa aa
a asjfowej
String arr[][] = new String[3][2];
Scanner cin = new Scanner(System.in);
for(int i =0;i<3;i++ ){
arr[i][0] = cin.next();
arr[i][1] = cin.next();
}
Arrays.sort(arr,new Comparator<String []>() {
@Override
//判断,第一列是否相等,不相等则,使用第二列作为判断条件
public int compare(String[] aa, String[] bb) {
if(aa[0].compareTo(bb[0])==0){
return aa[1].compareTo(bb[1]);
}
return aa[0].compareTo(bb[0]);
}
});
for(int i =0;i<3;i++){
System.out.print(arr[i][0]+" "+arr[i][1]);
System.out.println();
}
aaa aaa
aaa aa
a asjfowej
输出结果是:
a asjfowej
aaa aa
aaa aaa
比较一列的情况,就不在阐述了