Array.Sort()方法是根據元素的自然順序對指定的對象數組按升序進行排序,但是如果如果數組中的對象不是能直接進行比較的話,那麼會報錯,例如學生的成績進行排序,對象是學生,具有成績,學号,姓名的屬性。如果想對學生的成績進行排序,有兩種方法:
1.實作Comparable接口,并覆寫compareTo方法,按照你的意思進行排序
2.實作Comparator接口,并覆寫compare方法,按照你的意思進行排序
下面是我的兩種實作方法,對于其中的更深的内容還沒有了解,網大蝦指教。
package com.practice.ch10;
import java.util.Arrays;
public class Result implements Comparable{
int point; //成績
int no; //學号
String name; //姓名
public Result(int point,int no,String name)
{
this.point = point;
this.no = no;
this.name = name;
}
public int compareTo(Object o) {
int point_cp = ((Result)o).point;
int no_cp = ((Result)o).no;
//1.隻按成績排return (point < point_cp ? -1 : (point == point_cp ? 0 :1 ));
// //2.先按成績排,再按姓名排
// String name_cp=((Result)o).name;
// if(point
// return -1;
// }else if (point>point_cp){
// return 1;
// }else{
// return name.compareTo(name_cp);
// }
//3.先按成績排,再按學号排
if(point
return -1;
}else if (point>point_cp){
return 1;
}else{
return no - no_cp;
}
}
public static void main(String[] args) {
Result[] ra = {new Result(90,2,"zhang"),new Result(83,1,"wang"),new Result(86,3,"lt"),new Result(86,5,"li"),new Result(86,4,"ls")};
System.out.println("原始資料");
for(int i=0;i
{
System.out.println(ra[i].no + "," + ra[i].name + "," +ra[i].point);
}
System.out.println("**************************************");
System.out.println("按成績和學号排序後");
Arrays.sort(ra);
for(int i=0;i
{
System.out.println(ra[i].no + "," + ra[i].name + "," +ra[i].point);
}
System.out.println("**************************************");
System.out.println("按成績和姓名排序後");
Arrays.sort(ra,new ComResultComparator());
for(int i=0;i
{
System.out.println(ra[i].no + "," + ra[i].name + "," +ra[i].point);
}
}
}
package com.practice.ch10;
import java.util.Arrays;
import java.util.Comparator;
class ComResultComparator implements Comparator { public int compare(Object o1, Object o2) { int point1 = ((Result) o1).point; String name1 = ((Result) o1).name; int point2 = ((Result) o2).point; String name2 = ((Result) o2).name; //return (no1 < no2 ? -1 : (no1 == no2 ? 0 : 1)); if(point1 < point2){ return -1; }else if(point1 > point2){ return 1; }else { return name1.compareTo(name2); } }}