6-3 可排序的学生类 (15 分)

6-3 可排序的学生类 (15 分)

要求:根据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

作者: 张峰

单位: 山东科技大学

时间限制: 400 ms

内存限制: 64 MB

 

 

显而易见这种题没人写博客,那我就写了...

排序肯定要写的,七分基本都死在了没重载hashcode和equals(比如我敏哥),不然stuset其实没有去重作用,代码如下.

class Student implements Comparable<Student>
{
	int no;
	String name;
	public Student() {
		// TODO Auto-generated constructor stub
		no = 0;
		name = "";
		
	}
	public Student(int a,String b)
	{
		no = a;
		name = b;
	}
	@Override
	public String toString() {
		// TODO Auto-generated method stub
		return "no="+no+"&name="+name;
	}
	@Override
	public int compareTo(Student arg0) {
		// TODO Auto-generated method stub
		int a = 0,i,j;
		int l1 = name.length(),l2 = arg0.name.length();
		for(i=0,j=0;i<l1 && j<l2;i++,j++)
		{
			if(name.charAt(i) != arg0.name.charAt(j))
			{
				if(name.charAt(i) < arg0.name.charAt(j))
					return -1;
				else return 1;
			}
		}
		
		if(i == l1 && j < l2)
			return -1;
		else if(i < l2 && j == l2)
			return 1;
		else if(no < arg0.no)
			return -1;
		else if(no > arg0.no)
			return 1;
		return 0;
	}
	@Override
	public int hashCode() {
		// TODO Auto-generated method stub
		return no;
	}
	@Override
	public boolean equals(Object obj) {
		// TODO Auto-generated method stub
		Student aStudent = (Student)obj;
		if(no == aStudent.no)
			return true;
		return false;
	}
}

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. (编程题) 1、功能概述(1)学生管理系统具有录入、查找、删除、修改、排序和显示六大功能模块。 (2)请按照下面的定义及函数原型编程 #define MAX_LEN  10                     //字符串最大长度 #define STU_NUM 30                      //最多的学生人数 #define FORMAT "%-10d%-10s%-10.0f\n"    //输出格式 #define FNAME "studata.dat"              //数据文件 //结构体 struct student           //定义学生成绩结构体 {       int num;                //学号      char name[MAX_LEN];  //姓名      float score;      //课程成绩 }; //函数声明 struct student stu[STU_NUM];  //定义结构体数组 void in();                              //录入学生信息 void show();                         //显示学生信息 void order();                         //按成绩排序 void del();                            //删除学生信息 void modify();                       //修改学生成绩信息 void menu();                        //主菜单 void search();                       //查找学生信息 int ReadAll();                  //读取所有学生信息,返回学生总数 (3)数据以磁盘文件形式保存  2、  运行参考界面如下:  
05-25
抱歉,我无法提供图形化界面展示。但我可以根据您提供的代码,解释每个功能模块的作用和实现方式。 1. 录入学生信息(in()函数) 该函数用于录入学生信息,包括学号、姓名、和课程成绩。录入的数据将保存在结构体数组,并写入到磁盘文件。 2. 显示学生信息(show()函数) 该函数用于显示所有学生的信息,包括学号、姓名、和课程成绩。显示时按照指定的格式输出(FORMAT常量),并从磁盘文件读取数据。 3. 按成绩排序(order()函数) 该函数用于按照学生的课程成绩对学生进行排序排序后,将学生的信息保存到磁盘文件。 4. 删除学生信息(del()函数) 该函数用于删除指定学生的信息。需要输入学生的学号,并在结构体数组查找对应的学生信息。如果找到,则将该学生的信息删除,并将剩余的学生信息保存到磁盘文件。 5. 修改学生成绩信息(modify()函数) 该函数用于修改指定学生的课程成绩。需要输入学生的学号,并在结构体数组查找对应的学生信息。如果找到,则修改该学生的成绩,并将修改后的学生信息保存到磁盘文件。 6. 主菜单(menu()函数) 该函数用于显示主菜单,提供各个功能模块的选项,让用户选择需要执行的操作。 7. 查找学生信息(search()函数) 该函数用于查找指定学生的信息。需要输入学生的学号,并在结构体数组查找对应的学生信息。如果找到,则显示该学生的信息。 8. 读取所有学生信息(ReadAll()函数) 该函数用于从磁盘文件读取所有学生的信息,并返回学生的总数。 以上是学生管理系统的六大功能模块及其实现方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值