3

在 Java 中,

Class StudentProgress
{
        String Name;
        String Grade;
        /* CTOR goes here */
}

main class
{
     main method()
     {
         StudentProgress arrayofObjects[100000];
     }
}

如果成绩是 D-,C-,B-,A-,A,B,C,D,A+,B+,C+,D+。我需要对这些对象进行排序我怎样才能有效地做到这一点提前谢谢

4

2 回答 2

6

你最好的方法是让你的类实现Comparable。像这样的东西会起作用:

public class StudentProgress implements Comparable<StudentProgress> {

    String name;
    String grade;
    char baseGrade;    // Just the letter
    int gradeModifier; // -1 0 or +1 - done to make sorting easier

    public StudentProgress( String name, String grade ) {
        this.name = name;
        this.grade = grade;
        // Extract the grade parts for use when comparing
        baseGrade = grade.charAt( 0 );
        gradeModifier = grade.length() == 1 ? 0 : Integer.parseInt( grade.charAt( 1 ) + "1" );
    }

    public int compareTo( StudentProgress o ) {
        return baseGrade == o.baseGrade ? gradeModifier - o.gradeModifier : baseGrade - o.baseGrade;
    }
}

然后进行排序,您只需使用以下Arrays.sort()方法:

StudentProgress[] array = ...;
Arrays.sort(array);

如果你不希望你的类实现这个接口,你可以提供一个独立Comparator的 sort 调用

于 2012-07-11T01:55:30.007 回答
3

您正在寻找的类是 Comparable 和 Comparator。

本教程将指导您,http://www.mkyong.com/java/java-object-sorting-example-comparable-and-comparator/

祝你好运!

于 2012-07-11T01:41:44.277 回答