7-1 容器-ArrayList-排序分数 100作者 蔡轲单位 南昌航空大学题目描述编辑输入多个学生的成绩信息,包括:学号、姓名、数学成绩、物理成绩。学号是每个学生的唯一识别号,

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner reader = new Scanner(System.in);
        List<Student> students = new ArrayList<>();
        while (reader.hasNextLine()) {
            String line = reader.nextLine().trim();
            if ("end".equals(line)) {
                break;
            } else {
                String[] infos = line.split("\\s+");
                Student student = new Student(infos[0], infos[1], Integer.parseInt(infos[2]), Integer.parseInt(infos[3]));
                students.add(student);
            }
        }

        Collections.sort(students, (a, b) -> {
            int abSum = a.math + a.physic;
            int bbSum = b.math + b.physic;
            if (abSum != bbSum) {
                return bbSum - abSum;
            } else {
                return students.indexOf(a) - students.indexOf(b);
            }
        });

        for (Student student : students) {
            System.out.println(String.format("%s %s %d", student.num, student.name, student.math + student.physic));
        }
    }

    static class Student {
        String num;
        String name;
        int math;
        int physic;

        public Student(String num, String name, int math, int physic) {
            this.num = num;
            this.name = name;
            this.math = math;
            this.physic = physic;
        }
    }
}
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,我理解了你的问题。看起来你需要一个程序来接收并存储多个学生成绩信息,并按照学号从大到小的顺序输出所有学生信息,对吗?我可以提供一个Java程序来实现这个功能。以下是程序代码: ```java import java.util.*; class Student implements Comparable<Student> { private String id; private String name; private int score; public Student(String id, String name, int score) { this.id = id; this.name = name; this.score = score; } public String getId() { return id; } public String getName() { return name; } public int getScore() { return score; } @Override public int compareTo(Student o) { return o.getId().compareTo(this.getId()); } @Override public String toString() { return id + " " + name + " " + score; } } public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); Map<String, Student> map = new HashMap<>(); while (true) { String input = scanner.nextLine(); if (input.equals("end")) { break; } String[] tokens = input.split(" "); String id = tokens[0]; String name = tokens[1]; int score = Integer.parseInt(tokens[2]); Student student = new Student(id, name, score); map.put(id, student); } List<Student> students = new ArrayList<>(map.values()); Collections.sort(students); for (Student student : students) { System.out.println(student); } } } ``` 程序首先定义了一个`Student`类,用来存储每个学生信息。`Student`类实现了`Comparable`接口,以便可以按照学号从大到小排序。然后,在`Main`类中,程序使用`Scanner`类来读取用户输入,并将每个学生信息存储在一个`HashMap`对象中。然后,程序将所有学生信息存储在一个`ArrayList`对象中,并使用`Collections.sort()`方法按照学号从大到小排序。最后,程序遍历`ArrayList`对象,并按照题目要求输出每个学生信息。 请注意,程序假定输入数据的格式是正确的,如果输入数据格式不正确,程序可能会抛出异常。另外,程序的输出格式必须与题目要求完全一致,否则可能会导致测试不通过。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值