java设计简单学生管理系统
本文实例为大家分享了java学生成绩管理系统,供大家参考,具体内容如下
要求:
完善Student类,Student类包含学号、姓名、年级、专业、三门功课的成绩(英语、高数、计算机)的成员变量,完善成绩录入方法、设计按学号查找方法、按姓名查找方法、按单科成绩排序的方法。
设计主类,实例化包含5个学生信息的学生数组,查找某一个学生的信息并打印出来,同时打印这5个学生按某一科成绩的按高到低的排序信息(学号、姓名、成绩);输出所有学生的三门单科平均成绩。
首先先创建一个student类
使用构造方法来初始化
学号、姓名、年级、专业、三门功课的成绩
先打包
在分类

student类
使用构造方法初始化 get和set方法传值
package swpu.student;
public class Student {
public String number;
public String name;
public String major;
public int math;
public int computer;
public int english;
public int total;
//对象数组初始化,使用构造方法
public Student(String newname,String nmajor,String newnumber,int nmath,int ncom,int ne){
number = newnumber;
major =nmajor;
name = newname;
math = nmath;
computer = ncom;
english = ne;
}
public String getMajor() {
return major;
}
public void setMajor(String major) {
this.major = major;
}
public int getEnglish() {
return english;
}
public void setEnglish(int english) {
this.english = english;
}
public String getNumber() {
return number;
}
public void setNumber(String number) {
this.number = number;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getMath() {
return math;
}
public void setMath(int math) {
this.math = math;
}
public int getComputer() {
return computer;
}
public void setComputer(int computer) {
this.computer = computer;
}
}
排序类
rank类
package swpu.student;
public class Rank {
public static void rankscore(Student [] arr,int n){
//数学
if(n==1) {
for (int i = 0; i < arr.length-1; i++) {
int index = i;
int j;
// 找出最小值得元素下标
for (j = i + 1; j < arr.length; j++) {
if (arr[j].math > arr[index].math) {
index = j;
}
}
int tmp = arr[index].math;
arr[index].math = arr[i].math;
arr[i].math = tmp;
}
}
//英语
if(n==2) {
for (int i = 0; i < arr.length-1; i++) {
int index = i;
int j;
// 找出最小值得元素下标
for (j = i + 1; j < arr.length; j++) {
if (arr[j].english > arr[index].english) {
index = j;
}
}
int tmp = arr[index].english;
arr[index].english = arr[i].english;
arr[i].english = tmp;
}
}
//计算机
if(n==3) {
for (int i = 0; i < arr.length-1; i++) {
int index = i;
int j;
// 找出最小值得元素下标
for (j = i + 1; j < arr.length; j++) {
if (arr[j].computer > arr[index].computer) {
index = j;
}
}
int tmp = arr[index].computer;
arr[index].computer = arr[i].computer;
arr[i].computer = tmp;
}
}
}
}
这里使用了静态方法传入成绩的值
查找类
search类
package swpu.student;
public class Search {
//书写两种方法(学号,姓名)
public int StuNum(Student arr[] ,String y)//传入数组,查找值 ,使用字符串的比较
{
for(int i = 0;i<arr.length;i++)
{
if(arr[i].number.equals(y))
return i;
}
return -1;
}
public int StuNam(Student stu[] ,String x) {
for(int i = 0;i<stu.length;i++)
{
if(stu[i].name.equals(x))
return i;
}
return -1;
}
}
主要类
Instudent类
package swpu.student;
import java.util.Scanner;
public class Instudent {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner in = new Scanner(System.in);
Student []stu = new Student[5];
//学生成绩初始化
stu[0] = new Student("Jack","软工 ","20183101",80,90,85);
stu[1] = new Student("Rose","大数据","20183102",99,93,90);
stu[2] = new Student("John","网安全","20183103",87,70,74);
stu[3] = new Student("Andi","网工程","20183104",67,66,68);
stu[4] = new Student("Mike","物联网","20183105",56,90,55);
//局部变量的初始化
String nu1 = "";
String na1 = "";
String ma1 = "";
int t1=0,t2=0,t3=0;
System.out.println("-------------------学生成绩管理系统------------------------");
//输入学生信息
for(int i=0;i<stu.length;i++) {
System.out.println("请输入第"+(i+1)+"个学生的姓名,专业,学号,数学成绩,计算机成绩,英语成绩");
na1 = in.next();//姓名
ma1 = in.next();//专业
nu1 = in.next();//学号
t1 = in.nextInt();
t2 = in.nextInt();
t3 = in.nextInt();
stu[i].setNumber(nu1);
stu[i].setName(na1);
stu[i].setMajor(ma1);
stu[i].setEnglish(t3);
stu[i].setComputer(t2);
stu[i].setMath(t2);
}
Search search = new Search();
//选择需要的查找的方法
System.out.println("选择需要的查找的方法, 1学号,2姓名");
int p = in.nextInt();
if(p==1) {
//使用学号的方法进行查找
System.out.println("输入您所需要查找的学生学号");
String y = in.next();
int x = search.StuNum(stu,y);
if(x>=0)
System.out.println("学号:"+stu[x].number+" 学生:"+stu[x].name+" 专业:"+stu[x].major+" 数学:"+stu[x].math+" 计算机:"+stu[x].computer+" 英语:"+stu[x].english);
else
System.out.println("输入的学生不存在");
}
if(p==2) {
//使用姓名的方法进行查找
System.out.println("输入您所需要查找的学生姓名");
String thename = in.next();
int w = search.StuNam(stu,thename);
if(w>=0)
System.out.println("学号:"+stu[w].number+" 学生:"+stu[w].name+" 专业:"+stu[w].major+" 数学:"+stu[w].math+" 计算机:"+stu[w].computer+" 英语:"+stu[w].english);
else
System.out.println("输入的学生不存在");
}
System.out.println("是否需要对单科成绩进行排名 [Y/N] 1 =yes,2=no");
int op = in.nextInt();
if(op==1) {
//单科成绩的排序(输入所需要科目然后直接进行排序)
Rank rank = new Rank();//创建对象
System.out.println("输入所需要排序的成绩编号 , 1:数学,2:英语,3:计算机");
int major = in.nextInt();
rank.rankscore(stu,major);
//输出排序后的成绩
for(int i = 0;i < stu.length;i++) {
System.out.println("学号:"+stu[i].number+" 学生:"+stu[i].name+" 专业:"+stu[i].major+" 数学:"+stu[i].math+" 计算机:"+stu[i].computer+" 英语:"+stu[i].english);
}
}
else {
System.out.println("结束,退出系统");
}
}
}
其中使用构造方法初始化的时已经存入了值,因此在使用set方法输入学生信息时其实是修改学生信息,在构造方法初始化的时候可以不用那么复杂 可直接根据数据类型 例如:
stu[0] = new Student(" "," "," ",0,0,0);
stu[1] = new Student(" "," "," ",0,0,0);
stu[2] = new Student(" "," "," ",0,0,0);
stu[3] = new Student(" "," "," ",0,0,0);
stu[4] = new Student(" "," "," ",0,0,0);
注意 在声明局部变量的时候一定要记住初始化,否则将值传入数组的时候会出现报错
运行截图:


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
Springboot的Mapper中添加新的SQL语句方法详解
在如今的软件开发界,Spring Boot可是非常受欢迎的框架哦,尤其是在微服务和RESTful API的构建上,下面给大家介绍我们如何为Spring Boot项目中的Mapper添加新的SQL语句吧,感兴趣的朋友一起看看吧2025-04-04
RestTemplate Get请求实现bean参数传递详解
RestTemplate 是从 Spring3.0 开始支持的一个 HTTP 请求工具,也有的称之为网络框架,说白了就是Java版本的一个postman,这篇文章主要介绍了详解RestTemplate 用法,需要的朋友可以参考下2022-11-11
java组件commons-fileupload实现文件上传、下载、在线打开
这篇文章主要介绍了java组件commons-fileupload实现文件上传、下载、在线打开,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2016-10-10
springboot整合@Retryable实现重试功能的示例代码
本文主要介绍了springboot整合@Retryable实现重试功能的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-05-05
解决spirngboot连接redis报错:READONLY You can‘t write against
docker部署的redis,springboot基本每天来连redis都报错:READONLY You can't write against a read only replica,重启redis后,可以正常连接。但是每天都重启redis,不现实,也很麻烦,今天给大家分享解决方式,感兴趣的朋友一起看看吧2023-06-06
使用Spring Data R2DBC +Postgres实现增删改查功能
这篇文章主要介绍了使用Spring Data R2DBC +Postgres实现增删改查功能,本文通过两种方法给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-03-03


最新评论