day03 easy成绩排序

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版权协议,转载请附上原文出处链接和本声明。