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/
提示
如果你使用结构体,注意: 1.结构体中有数组(指针)成员时的,结构体变量之间的拷贝问题(深拷贝)。 2.请注意本题排序原则。
import java.util.Scanner;
public class Main{
public static void main(String[]args){
Scanner sc=new Scanner(System.in);
//输入有几个数据
int n=sc.nextInt();
//创建数组,使用数组来盛放数据
String name[]=new String[n];
int grade[]=new int [n];
//输如数据
for(int i=0;i<n;i++){
name[i]=sc.next();
grade[i]=sc.nextInt();
}
//将数据从大到小排列
for(int i=0;i<n;i++){
for(int j=0;j<n-i-1;j++){
if(grade[j]==grade[j+1]){
//当两个人的分数一样时,按字母大小排序
if(name[j].charAt(0)>name[j+1].charAt(0)){
int grade1=grade[j];
grade[j]=grade[j+1];
grade[j+1]=grade1;
String name1=name[j];
name[j]=name[j+1];
name[j+1]=name1;
}
}
else if(grade[j]<grade[j+1]){
int grade1=grade[j];
grade[j]=grade[j+1];
grade[j+1]=grade1;
String name1=name[j];
name[j]=name[j+1];
name[j+1]=name1;
}
}
}
//将数据输入,最后一行没有空行
for(int i=0;i<n;i++){
if(i==(n-1)){
System.out.print(name[n-1]+" "+grade[n-1]);
}
else
System.out.println(name[i]+" "+grade[i]);
}
}
}