【问题描述】
从键盘中读入最多不超过50个学生的学生信息(包括空格隔开的姓名、学号、年龄信息,以学号从低到高排序)
【输入形式】
每次键盘读入最多不超过50个学生的学生信息:
第一行为学生人数;
后面每一行为空格隔开的学生学号、姓名、年龄,其中学号和年龄都是整数。
【输出形式】
分别以姓名顺序(从低到高)和年龄顺序(从低到高)将学生信息输出,每行输出一位学生的信息,其中学号占3位,姓名(英文)占6位,年龄占3位,均为右对齐。年龄相同时按姓名从低到高排序。两种顺序的输出结果用一行空行相隔。
【输入样例】
4
1 aaa 22
45 bbb 23
54 ddd 20
110 ccc 19
【输出样例】
1 aaa 22
45 bbb 23
110 ccc 19
54 ddd 20
110 ccc 19
54 ddd 20
1 aaa 22
45 bbb 23
【样例说明】
从键盘输入四个学生记录,分别按姓名和年龄排序并输出
import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;
class Student{//定义类体
int num;
String name;
int age;
}
class cmp implements Comparator<Student> {
public int compare(Student A, Student B) {
if(A.name.compareTo(B.name)>=0) return 1;
else return -1;
}
}
class cmp2 implements Comparator<Student> {
public int compare(Student A, Student B) {
if (A.age>B.age) return 1;
else if (A.age<B.age) return -1;
else {
if(A.name.compareTo(B.name)>=0) return 1;
else return -1;
}
}
}
public class cs3_3 {
public static void main(String[] args) {
Student[] sz = new Student[52];//这里只是声明,并没有真正申请内存
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
for (int i=0;i<n;i++) {
sz[i] = new Student();//一定要记得new一下,才能真正的申请内存
sz[i].num = sc.nextInt();
sz[i].name = sc.next();
sz[i].age = sc.nextInt();
}
sc.close();
Arrays.sort(sz,0,n,new cmp());//自定义排序方式排序
for (int i=0;i<n;i++) {
System.out.printf("%3d%6s%3d\n",sz[i].num,sz[i].name,sz[i].age);
}
System.out.println();
Arrays.sort(sz,0,n,new cmp2());
for (int i=0;i<n;i++) {
System.out.printf("%3d%6s%3d\n",sz[i].num,sz[i].name,sz[i].age);
}
}
}