题目描述
查找和排序
题目:输入任意(用户,成绩)序列,可以获得成绩从高到低或从低到高的排列,相同成绩
都按先录入排列在前的规则处理。
例示:
jack 70
peter 96
Tom 70
smith 67
从高到低 成绩
peter 96
jack 70
Tom 70
smith 67
从低到高
smith 67
Tom 70
jack 70
peter 96
输入描述:
输入多行,先输入要排序的人的个数,然后分别输入他们的名字和成绩,以一个空格隔开
输出描述:
按照指定方式输出名字和成绩,名字和成绩之间以一个空格隔开
示例1
输入
3 0 fang 90 yang 50 ning 70
输出
fang 90 ning 70 yang 50
看了一下jdk才发现java中的sort通过设置系统属性java.util.Arrays.useLegacyMergeSort,可以使用归并排序(稳定)
import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;
/**
* Created by mazhanbin on 2017/7/26.
*/
public class Main {
public static void main(String[] args){
Scanner in = new Scanner(System.in);
while(in.hasNext()){
int n = in.nextInt();
int flag = in.nextInt();
Student[] data = new Student[n];
for(int i = 0; i < n; i++){
data[i] = new Student(in.next(), in.nextInt());
}
System.setProperty("java.util.Arrays.useLegacyMergeSort", "true");//设置为使用归并排序,保证排序的稳定性
if(flag == 0){
Arrays.sort(data, new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
return o2.score - o1.score;
}
});
}
else{
Arrays.sort(data, new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
return o1.score - o2.score;
}
});
}
for(int i = 0; i < n; i++){
System.out.println(data[i].name + " " + data[i].score);
}
}
in.close();
}
public static class Student{
String name;
int score;
Student(String name, int score){
this.name = name;
this.score = score;
}
}
}