PTA Java 7-2 教师类-2 (20 分)

PTA Java 7-2 教师类-2 (20 分)

复习时又做到了这个题,感觉这个题描述的比较怪,因为照题目描述的方法实现很复杂(我自己找不到好的方法,也许是因为我比较菜),于是我用了个比较怪的方法,总之完全按照题目要求的写法不太好实现,不知道有没有什么好的方法。
我自认为我这个写法比较简洁,看着比较舒服,但还是比较怪。

这是一个关于接口的Java题,我觉得是对之前的一些小知识点的综合运用,觉得比较有纪念价值,记录一下。

关于教师类(1)可以在我的博客里找到

修改题目143

修改教师类,使得由多个Teacher对象所形成的数组可以排序(编号由低到高排序),并在main函数中使用Arrays.sort(Object[] a)方法排序
定义一个类TeacherManagement,包含教师数组,提供方法add(Teacher[]),使其可以添加教师,提供重载方法search,方法可以在一组给定的教师中,根据姓名或年龄返回等于指定姓名或年龄的教师的字符串信息,信息格式为:“no: , name:, age: **, seminary: **”。如果没有满足条件的教师,则返回“no such teacher”。
输入格式:
教师个数 教师信息 待查找教师的姓名 待查找教师的年龄

输出格式:
排序后的信息 按姓名查找的老师信息 按年龄查找的老师信息

输入样例:
在这里给出一组输入。例如:

4
3 Linda 38 SoftwareEngineering
1 Mindy 27 ComputerScience
4 Cindy 28 SoftwareEngineering
2 Melody 27 ComputerScience
Cindy
27
输出样例:
在这里给出相应的输出。例如:

no: 1, name: Mindy, age: 27, seminary: ComputerScience
no: 2, name: Melody, age: 27, seminary: ComputerScience
no: 3, name: Linda, age: 38, seminary: SoftwareEngineering
no: 4, name: Cindy, age: 28, seminary: SoftwareEngineering
search by name:
no: 4, name: Cindy, age: 28, seminary: SoftwareEngineering
search by age:
no: 1, name: Mindy, age: 27, seminary: ComputerScience
no: 2, name: Melody, age: 27, seminary: ComputerScience

//全文没有写get和set的方法就直接用了变量,感觉不太专业,但写起来很方便,正式写还是应该改一下

import java.util.Arrays;
import java.util.Scanner;

public class Main{
    public static void main(String[] args) {
         Scanner sc = new Scanner(System.in);
         int n;
         n = sc.nextInt();
         Teacher t[] = new Teacher[n];
         for(int i=0;i<n;i++)
        	 t[i] = new Teacher(sc.nextInt(),sc.next(),sc.nextInt(),sc.next());
         Arrays.sort(t);
         for(int i=0;i<n;i++)
        	 System.out.println(t[i].toString());
         TeacherManagement tt = new TeacherManagement(n);
         
         String name = sc.next();
         System.out.println("search by name:");
         for(int i=0;i<n;i++) {
        	 tt.add(t[i]);
        	 System.out.print(tt.search(name,i));
         }
         int age = sc.nextInt();
         System.out.println("search by age:");
         for(int i=0;i<n;i++) {
        	 tt.add(t[i]);
        	 System.out.print(tt.search(age,i));
         }
         sc.close(); 
    }
}


class Teacher implements Comparable<Teacher>{
	int no,age;
	String name,seminary;
	public Teacher(int no,String name,int age,String seminary) {
		this.no = no;
		this.name = name;
		this.age = age;
		this.seminary = seminary;
	}
	public boolean equals(Teacher t) {
		if(this.no == t.no)
			return true;
		else
			return false;
	}
	public String toString() {
		return "no: "+no+", name: "+name+", age: "+age+", seminary: "+seminary;
	}
	public int compareTo(Teacher t) {
		if(this.no >= t.no)
			return 1;
		else
			return -1;
	}
}


class TeacherManagement{
	Teacher t;
	int m;      //这个m是用来记录总个数的
	static boolean flag1 = true,flag2 = true;
	public TeacherManagement(int n) {
		m = n;
	}
	public void add(Teacher p) {
		t = p;
	}
	public String search(int age,int i) {
		if(t.age == age) {
			flag1 = false;
			return "no: "+t.no+", name: "+t.name+", age: "+t.age+", seminary: "+t.seminary+"\n";
		}
		if(flag1&&i==m-1)
		    return "no such teacher\n";
		return "";
	}
	public String search(String name,int i) {
		if(t.name.equals(name)) {
			flag2 = false;
			return "no: "+t.no+", name: "+t.name+", age: "+t.age+", seminary: "+t.seminary+"\n";
		}
		if(flag2&&i==m-1)
		    return "no such teacher\n";
		return "";
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值