java中类体的排序(类似C++结构体的排序)

【问题描述】
从键盘中读入最多不超过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);
		}
	}
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值