6-1 可排序的学生类 (20 分)面向对象程序设计(Java)期中考试题--计算机17-1,2

本文详细解析了如何设计一个包含学号和姓名属性的学生类,并实现了Comparable接口以支持姓名排序。同时,通过HashSet确保学生对象的唯一性,避免学号重复。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

6-1 可排序的学生类 (20 分)

要求:根据Main类中main方法中的代码,设计满足要求的Student(学生)类:1)包含属性:int no(学号)、String name(姓名);2)满足Main类中main方法代码的说明要求。 Main类中main方法代码的说明:1)首先,从键盘接收形如“3 cuizhenyu 2 tiangang 1 dingchangqing 4 zhangfeng”的字符串,该字符串中包含了4个学生的学号和姓名(各学生以及学生的学号和姓名之间都用一个空格分隔,姓名中只包含英文字母),然后将该字符串内容中的前3个学生的学号及其姓名放到到Student数组stus中;2)将stus中的3个Student放入到HashSet stuSet中(注意:如果学生的学号相同,则认为是相同对象,不放入stuSet中);3)将第4个学生对象放入到stuSet中,如果第4个学生对象的学号与stuSet中已有学生对象的学号相同则不能放入。然后,打印出当前stuSet中学生对象的个数;4)用Arrays.sort方法对数组stus按照学生姓名的字母顺序排序(先比较首字母,首字母相同的比较第二个字母,以此类推),输出排序后的stus中3个学生对象的内容,每个学生对象的输出格式为“no=XX&name=YY”。

函数接口定义:

Student

裁判测试程序样例:

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

public class Main{
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		Student[] stus = new Student[3];
		
		for(int i=0;i<3;i++){
			int no = scan.nextInt();
			String name = scan.next();
			Student s = new Student(no,name);
			stus[i] =s;
		}
		//将stus中的3个学生对象,放入到HashSet中
		HashSet<Student> stuSet = new HashSet<Student>();
		for(Student s: stus){
			stuSet.add(s);
		}
		//要放入的第4个Student
		Student fourth = new Student(scan.nextInt(),scan.next());
		stuSet.add(fourth);//如果fourth的学号(no)与stuSet中的已有学生的no重复则无法放入
		System.out.println(stuSet.size());
		
		Arrays.sort(stus);//对stus中的3个原有对象,按照姓名首字符有小到大排序
		for(int i=0;i<stus.length;i++){
			System.out.println(stus[i]);//输出的格式为:no=XX&name=YY
		}
		
		scan.close();
	}
}
/* 请在这里填写答案 */

输入样例:

3 cuizhenyu 2 tiangang 1 dingchangqing 4 zhangfeng

输出样例:

4
no=3&name=cuizhenyu
no=1&name=dingchangqing
no=2&name=tiangang

这个题真是太丢人了。。。 就是考察sort的两种方法Comparable和Comparator

本题因为主函数已经给出,用的是Arrays.sort,注意只有一个参数,那你就不能使用Comparator,所以直接实现Comparable接口并重写ToString方法即可

nm我跟Comparator捣鼓半天永远都不对。。。气爆

简单说一下,这个题要实现四个函数,重写toString,compareTo方法,equals方法,hashcode方法,然后要注意提交的时候Student类前不能有public(因为一个文件只能有一个public)

此外要注意equals方法,hashcode方法只针对变量no,与name无关

题目实现:

import zuiye1.Student;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Scanner;

public class Main{
	
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		Student[] stus = new Student[3];
		
		for(int i=0;i<3;i++){
			int no = scan.nextInt();
			String name = scan.next();
			Student s = new Student(no,name);
			stus[i] =s;
		}
		//将stus中的3个学生对象,放入到HashSet中
		HashSet<Student> stuSet = new HashSet<Student>();
		for(Student s: stus){
			stuSet.add(s);
		}
		//要放入的第4个Student
		Student fourth = new Student(scan.nextInt(),scan.next());
		stuSet.add(fourth);//如果fourth的学号(no)与stuSet中的已有学生的no重复则无法放入
		System.out.println(stuSet.size());
		
		Arrays.sort(stus);//对stus中的3个原有对象,按照姓名首字符有小到大排序
		for(int i=0;i<stus.length;i++){
			System.out.println(stus[i]);//输出的格式为:no=XX&name=YY
		}
		
		scan.close();
	}
}
/* 请在这里填写答案 */

Student实现 

package 函数题1;

class Student implements Comparable<Student>{
	@Override
	public int compareTo(Student t1) {
		// TODO Auto-generated method stub
		return this.getName().compareTo(t1.getName());
	}
	public int no;
	public String name;
	public Student(int no, String name) {
		this.no = no;
		this.name = name;
	}

	@Override
	public int hashCode() {
		final int prime = 31;
		int result = 1;
		result = prime * result + no;
		return result;
	}

	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
		Student other = (Student) obj;
		if (no != other.no)
			return false;
		return true;
	}

	public int getNo() {
		return no;
	}

	public void setNo(int no) {
		this.no = no;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	@Override
	public String toString()
	{
		//return "no="+this.no+"&name="+this.name;
		return "no="+this.no+"&name="+this.name;

	}
	

}

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值