学生管理系统

package firstjavapackage;

import java.util.Arrays;

/**
 * .学生管理系统: .学生的基本特征: 学号、姓名、性别、分数 .String、String、char、double
 */
public class StudentManagement {

	// 保存多个学生信息,使用数组
	Student[] students;// 成员变量
	// 定义一个初始化长度为5
	final int CAPACITY = 5;
	// 数组元素的有效个数
	int size;

	// 构造方法
	public StudentManagement() {
		// 初始化数组
		students = new Student[CAPACITY];
		size = 0;

		// **************************************
		// 中间添加一些测试的学生对象数据
		Student s1 = new Student();
		s1.sid = "s1001";
		s1.name = "张三";
		s1.gender = '男';
		s1.score = 90;

		Student s2 = new Student();
		s2.sid = "s1002";
		s2.name = "李四";
		s2.gender = '女';
		s2.score = 99;

		// 添加到数组中
		students[size++] = s1;
		students[size++] = s2;
		// **************************************

	}

	// 新增一个学生对象
	public void add(Student student) {
		// size + 1:添加之后的个数
		if (size + 1 > students.length) {// 是否扩容
			// 数组的复制
			students = Arrays.copyOf(students, CAPACITY + students.length);
		}
		// 添加元素
		students[size++] = student;
	}

	// 删除学生对象
	public boolean delete(String sid) {
		// 通过学号查询此学生是否存在
		int index = indexOf(sid);
		// 判断是否存在
		if (index == -1) {
			return false;
		}
		
		/*
		 * arraycopy(Object src,  int  srcPos,
                    Object dest, int destPos,
                    int length);
			src:源数组
			srcPos:从源数组的哪个下标开始
			dest:目标数组
			destPos:从目标数组的哪个下标开始
			length:需要复制的元素个数
		 */
		
		// 复制
		System.arraycopy(students, index + 1, students, index, size - (index + 1));
		// 计数器减少
		size--;
		// 返回删除成功的标志
		return true;
	}

	// 修改学生对象
	public boolean update(Student student) {
		// 通过学号查询此学生是否存在
		int index = indexOf(student.sid);
		// 判断是否存在
		if (index == -1) {
			return false;
		}
		// 修改操作
		students[index] = student;
		// 返回修改成功的标志
		return true;
	}

	// 通过学号查询学生信息
	public Student select(String sid) {
		// 通过学号查询此学生是否存在
		int index = indexOf(sid);
		// 判断是否存在
		if (index == -1) {
			return null;
		}
		// 如果存在,直接返回该下标对应的元素
		return students[index];
	}

	// 通过传入的学号,得到此学生对象在数组中的下标
	private int indexOf(String sid) {
		// 判断数组长度是否为0
		if (size == 0) {
			return -1;// 找不到
		}
		// 遍历数组
		for (int i = 0; i < size; i++) {
			// 通过下标取出数组中的元素
			if (sid.equals(students[i].sid)) {
				return i;// 返回找到的下标
			}
		}
		// 找不到。返回-1
		return -1;
	}

	// 得到数组的实际有效元素的个数
	public int getLength() {
		return size;
	}

	// 遍历所有的学生信息
	public void printStudent() {
		if (size == 0) {
			System.out.println("暂无学生信息...");
			return;
		}
		System.out.println("学号\t姓名\t性别\t分数");
		for (int i = 0; i < size; i++) {
			System.out.println(students[i]);
		}
	}
	//按成绩降序排序
			public void sortDownAtScore(){
				if (size == 0) {
					System.out.println("暂无学生信息,无法排序");
					return;
				}
				double swap=0;
				for(int i=0;i<size-1;i++)
				{
					for(int j=i+1;j<size;j++)
					{
						if(students[i].score<students[j].score)
						{
							swapDownAtScore(i,j);
						}
					}
				}
				System.out.println("排序成功,结果如下:");
				printStudent();
			}
	//交换数据
			public void swapDownAtScore(int i,int j)
			{
				String sid="";// 学号
				String name="";// 姓名
				char gender='\0';// 性别	
				double score=0;// 分数
				sid=students[j].sid;
				name=students[j].name;
				gender=students[j].gender;
				score=students[j].score;
				
				students[j].sid=students[i].sid;
				students[j].name=students[i].name;
				students[j].gender=students[i].gender;
				students[j].score=students[i].score;
				
				students[i].sid=sid;
				students[i].name=name;
				students[i].gender=gender;
				students[i].score=score;
				
			}

	// 程序入口函数
	public static void main(String[] args) {
		StudentManagement sm = new StudentManagement();

		Student s1 = new Student();
		s1.sid = "s1003";
		s1.name = "王五";
		s1.gender = '男';
		s1.score = 97;
		// 添加方法
		sm.add(s1);

		int length = sm.getLength();
		System.out.println("学生个数:" + length);

		// 遍历所有的学生信息
		sm.printStudent();
		
		// 删除一个学生信息
		boolean isSuccess = sm.delete("s10020");
		System.out.println(isSuccess);
		
		sm.printStudent();
		sm.sortDownAtScore();
	}

}

//自定义学生实体类
class Student {
	// 下面是属性
	String sid;// 学号
	String name;// 姓名
	char gender;// 性别	
	double score;// 分数

	public String toString() {
		return sid + "\t"+ name + "\t" + gender + "\t" + score;
	}
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
vs2015+数据库,需要建的数据表如下: 1. “考试成绩管理系统用户登录”功能 具体要求: (1) 按照图示排列相应的控件,控件名称自定义,其中,界面中的图片可以不加; (2) 当输入正确的用户名和密码时,登录到主系统,如图所示,并且用户名或密码输入不正确时系统有所提示;当单击【取消】按钮时,用户名和密码被清空; (3) 程序中用到的数据库名为SCOREINFO,数据表名为userinfo,数据表结构如下图所示: (4) 数据表中的用户名和密码如下图。 2. 点击主窗体的“密码修改”菜单,完成“密码修改”功能,程序运行如下图所示: 具体要求: (1)此题必须使用数据库连接完成,原始密码必须为数据表里原有的数据,不使用数据库完成的为0分。 (2)需要建立数据库SCOREINFO及数据表userinfo,表的结构及数据第一部分的内容: (3)要有“原始密码输入错误”、“原始密码不能为空”及“两次输入密码不一致”的错误提示; (4)当单击【保存】按钮,新密码被更新到数据表中,不能更新的为0分; (5)单击【关闭】按钮,窗口关闭。 (6)3个Label;3个TextBox;2个Button 3. 完成“成绩查询”功能,程序运行如下图所示: 具体要求: (1) 按照图示排列相应的控件,界面下方是DataGridView控件; (2)程序用到的数据库名为SCOREINFO,数据表名为score,表结构如下: (3)完成的MainForm_Load事件处理程序:当加载窗体时,直接在窗体的dataGridView1控件中显示数据表的所有记录; (4)可以设查询条件:首先在组合框comboBox1中选择查询条件,并在textBox1中输入条件值(可以模糊查询,如按照姓名查询时,输入“王”,可以查所有姓王的同学的成绩),单击查询将结果显示在dataGridView1控件中。 (5)所需控件及属性:1个GroupBox,1个Label,Text为选择查询条件;1个ComboBox(Items:学号、姓名);1个TextBox;1个Button,Text为查询;1个DataGridView 4. 完成“课程信息修改”功能,程序运行如下图所示: 具体要求: (1)按照图示排列相应的控件,控件名称自定义,其中,程序刚开始运行时,“学分”和“课程编码”的文本框是只读的; (2)在数据库名为SCOREINFO中,创建数据表名为course,表结构如下: (3)当单击【查询】时,直接在窗体的dataGridView2控件中显示数据表的所有记录; (4)当选中DataGridView控件中的某一行记录时(DataGridView控件的Mouse_Click事件),“课程名字”、“学分”、“课程代码”文本框中分别显示该项对应的课程信息; (5)当选中某一行记录并单击【编辑】按钮时,【编辑】按钮变为【保存修改】,同时“学分”和“课程编码”的文本框恢复正常(ReadOnly属性为false);在文本框中修改相应的信息后单击【保存修改】,将修改后的数据更新到数据表中。 (6)所需控件及属性:1个GroupBox,3个Label;3个TextBox(textBox2属性ReadOnly为True,textBox3属性ReadOnly为True);2个Button;1个DataGridView 5. 完成“课程信息删除”功能,程序运行如下图所示: 具体要求: (1)按照图示排列相应的控件,控件名称自定义,其中,程序刚开始运行时,“学分”和“课程编码”的文本框是只读的; (2)数据表名为course,表结构同第4部分: (3)当单击【查询】时,直接在窗体的dataGridView控件中显示数据表的所有记录; (4)当选中DataGridView控件中的某一行记录时,“课程名字”、“学分”、“课程代码”文本框中分别显示该项对应的课程信息; (5)当选中某一行记录并单击【删除】按钮时,则该行从数据表中删除。 (6)所需控件:3个Label;3个TextBox(textBox2属性ReadOnly为True,textBox3属性ReadOnly为True);2个Button;1个DataGridView 6. 完成“课程信息添加”功能,程序运行如下图所示: 具体要求: (1)按照图示排列相应的控件,控件名称自定义; (2)程序用到的数据库和数据表名为course,表结构如下同第四部分: (3)当单击【查询】时,直接在窗体的dataGridView1控件中显示数据表的所有记 (4)当选中DataGridView控件中的某一行记录时,“课程名字”、“学分”、“课程代码”文本框中分别显示该项对应的课程信息; (5)当单击【添加】按钮时,在文本框中添加新的内容并将新内容添加到数据表中,并且在DataGridView控件中显示出新的课程信息 (6)所需控件:3个Label;3个TextBox;2个Button;1个DataGridView

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值