7-2 sdust-Java-学生成绩读取与排序 (8 分)

**

7-2 sdust-Java-学生成绩读取与排序 (8 分)

**

1)从键盘录入多行学生成绩的信息,每行表示一个学生的一门课的成绩,最后一行以“exit”结束。每行文本的格式为:学号,姓名,课程名,成绩。程序能够读取学生及其成绩,将具有相同学号的学生及其成绩读取到一个Student(学生类)类对象的列表(List)stuList中; 2)程序在读取完学生及其成绩的数据后,能够将stuList中的学生按照平均成绩降序排列(如果平均成绩相同,学号数字小的排在前面), 并输出排序后的学生学号、姓名和成绩。

输入格式:
多行表示的学生成绩,每一行是一个学生的姓名、学号、课程名、成绩(整数)。不同行可以是同一名学生(学号相同的为同一名学生)不同课程的成绩。

输出格式:
按照学生平均成绩降序排序(平均成绩相同的学号小的在前面)的学生排名(具体输出格式参照样例)。

输入样例:
小明,2001,Java,88
小刚,2002,Java,78
小丁,2003,Java,56
小宏,2004,Java,85
小明,2001,Python,84
小刚,2002,Python,98
小丁,2003,JavaWeb,66
小宏,2004,Algorithm,87
exit
输出样例:
No1:2002,小刚
No2:2001,小明
No3:2004,小宏
No4:2003,小丁

分析:本身题目并不算什么难题,题目关键点在于对于输入的学生信息的判断,如果学生信息已经存在就需要我们将其添加到已经有的集合中去,
而如果并不存在那么便需要创建一个新的对象并把它放入集合中。
(中间注释掉的部分是当初在调试时所加入的调试点,以及调试用的方法)

import java.util.*;
class Student implements Comparable{
    private String name,id;
    private int subject=1;
    private int score;
    private double sum=0;
    Student(){}
    Student(String name,String id,int score){
             this.name=name;
             this.id=id;
             this.score=score;
    }
    public String getid(){
        return this.id;
    }
    public void subjectadd() {
        this.subject++;
    }
    public void scoreadd(int score){
        this.score=this.score+score;
    }
    public String getname() {
        return this.name;
    }
    public void sum() {
        this.sum=this.score/this.subject;
    }
   /*public int rescore() {
        return this.score;
    }*/
   /* public double getsum(){
        return this.sum;
    }*/
    public int compareTo(Student o1){
               Student one = (Student) o1;
               if(this.sum-one.sum!=0)
               return (int)(one.sum-this.sum);
               else
               return this.id.compareTo(one.id);
    }
}
public class Main{
    public static void main(String[] args) {
            Scanner sc=new Scanner(System.in);
            List list =new ArrayList();
            int i,flag=0;
            String k;
            String[] and =new String[5];

            while(sc.hasNext())
            {
                k=sc.next();
                and=k.split(",");
                if(k.compareTo("exit")==0)
                break;
                for(i=0;i

import java.util.Arrays;
import java.util.Scanner;
import java.util.*;

你可能感兴趣的:(基础题类)