7-3 成绩排序
分数 10
作者 于延
单位 哈尔滨师范大学
描述
给出班里某门课程的成绩单,请你按成绩从高到低对成绩单排序输出,如果有相同分数则名字字典序小的在前。
输入
第一行为n (0 < n < 20),表示班里的学生数目;
接下来的n行,每行为每个学生的名字和他的成绩, 中间用单个空格隔开。名字只包含字母且长度不超过20,成绩为一个不大于100的非负整数。
输出
把成绩单按分数从高到低的顺序进行排序并输出,每行包含名字和分数两项,之间有一个空格。
样例输入
4
Kitty 80
Hanmeimei 90
Joey 92
Tim 28
样例输出
Joey 92
Hanmeimei 90
Kitty 80
Tim 28
题目来源
http://noi.openjudge.cn/ch0110/03/
import java.util.Arrays;
import java.util.Scanner;
//4
//Kitty 80
//Hanmeimei 90
//Joey 92
//Tim 28
class easy成绩排序 {
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
// 在此输入您的代码...
int n = scan.nextInt();
Student stulist[] = new Student[n];
for (int i = 0; i < n; i++) {
stulist[i] = new Student();
stulist[i].name = scan.next();
stulist[i].soc = scan.nextInt();
}
Arrays.sort(stulist);
for (int i = 0; i < n; i++) {
if (i == (n - 1)) {
System.out.print(stulist[i].toString());
} else
System.out.println(stulist[i].toString());
}
scan.close();
}
}
class Student implements Comparable<Student> {
String name;
int soc;
@Override
public String toString() {
return this.name + " " + this.soc;
}
@Override
public int compareTo(Student o) {
if (this.soc != o.soc) {
return o.soc - this.soc;
} else {
return this.name.charAt(0) - o.name.charAt(0);
}
}
}
版权声明:本文为weixin_53021364原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。