最近小編,在積極備戰秋招大戰,在編程題方面,許多題目用到了排序,都用到 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
比較一列的情況,就不在闡述了