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.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
ArrayList<Student> stu=new ArrayList<Student>();
boolean f=true;
while(true){
f=true;
String[] s= sc.nextLine().split(",");
if (s[0].equals("exit"))break;
for (Student ss:stu){
if (ss.getNum().equals(s[1])){
ss.setScore(((ss.getScore()+Double.parseDouble(s[3]))/2));
f=false;
}
}
if (f) stu.add(new Student(s[0],s[1],s[2],Double.parseDouble(s[3])));
}
stu.sort(new Newcompartor());
int i=1;
for (Student s:stu){
System.out.println("No"+i+":"+s.toString());
i++;
}
}
}
class Student{
private String name;
private String num;
private String clazz;
private double score;
public Student(String name, String num, String clazz, double score) {
this.name = name;
this.num = num;
this.clazz = clazz;
this.score = score;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getNum() {
return num;
}
public void setNum(String num) {
this.num = num;
}
public String getClazz() {
return clazz;
}
public void setClazz(String clazz) {
this.clazz = clazz;
}
public double getScore() {
return score;
}
public void setScore(double score) {
this.score = score;
}
@Override
public String toString() {
return num +","+ name;
}
}
class Newcompartor implements Comparator<Student>{
@Override
public int compare(Student o1, Student o2) {
double ret= o1.getScore()-o2.getScore();
if (ret>0)ret=-1;
else if (ret<0)ret=1;
else{
ret=Integer.parseInt(o1.getNum())-Integer.parseInt(o2.getNum());
if (ret>0){
ret=1;
}else if (ret<0){
ret=-1;
}
}
return (int)ret;
}
}