java实现学生成绩档案管理系统

本文实例为大家分享了java实现学生成绩档案管理系统的具体代码,供大家参考,具体内容如下

实验要求

• 学生信息录入,信息包括学号、姓名、专业、四门课成绩、总分、名次;
• 系统可对学生信息浏览、增加、删除和修改;
• 按学生成绩确定名次及信息输出,双向冒泡排序、希尔排序、快速排序、堆 排序。
• 要求可对学生信息查询,根据学号或姓名进行查找;
• 信息修改仅可修改四门课成绩;
• 文件存取学生信息

实验设计

• 新增学生信息(包括学号、姓名、专业、4门课成绩……)
• 浏览学生信息(对学生排序后信息进行浏览)
• 删除学生信息(删除指定学生的信息,可给用户选择检索指定项)
• 查找学生信息(查找符合条件的某条记录)
• 保存学生信息(保存学生成绩档案信息到文本文件)
• 加载学生信息(登录系统后将磁盘文件中保存的学生成绩信息读
取到内存中)

实验分析

初步分析

本实验采用dao模式进行编写,由于暂时没有学习数据库,故新建一个类来模拟保存数据库,此外,本人想法是将数据保存于excel文件中,并从excel文件中读取数据。

算法设计

快速排序

 /**
     * 快速排序
     * 递归
     */
    private void quickSort(List<StuInfo> stuInfosList, int left, int right) {
        if (left >= right) {
            return ;
        }
        int l = left;
        int r = right;
        //基准值,取中间
        int key = stuInfosList.get(left).getSum();

        boolean flag=true;
        //交换容器
        StuInfo student;
        while (l != r) {

            if(flag){
                if(key<stuInfosList.get(r).getSum()){
                    student = stuInfosList.get(r);
                    stuInfosList.set(r, stuInfosList.get(l));
                    stuInfosList.set(l, student);
                    flag=false;
                }else{
                    r--;
                }
            }else {
                if (key>stuInfosList.get(l).getSum()){
                    student = stuInfosList.get(r);
                    stuInfosList.set(r, stuInfosList.get(l));
                    stuInfosList.set(l, student);
                    flag=true;
                }else {
                    l++;
                }
            }
        }
        quickSort(stuInfosList,left, r - 1);
        quickSort(stuInfosList, l + 1, right);
}

双向冒泡排序

/**
     * 双向冒泡排序
     */
    private void doubleBubbleSort(List<StuInfo> stuInfosList) {
        //设置一个交换容器
        StuInfo student;
        //左右指针
        int left = 0, right = stuInfosList.size() - 1;
        while (left < right) {
            for (int i = left + 1; i <= right; i++) {
                if (stuInfosList.get(left).getSum() < stuInfosList.get(i).getSum()) {
                    student = stuInfosList.get(i);
                    stuInfosList.set(i, stuInfosList.get(left));
                    stuInfosList.set(left, student);
                }
            }
            left++;
            for (int i = right; i >= left; i--) {
                if (stuInfosList.get(right).getSum() > stuInfosList.get(i).getSum()) {
                    student = stuInfosList.get(i);
                    stuInfosList.set(i, stuInfosList.get(right));
                    stuInfosList.set(right, student);
                }
            }
            right--;
        }
    }

堆排序

/**
     * 堆排序
     */
    private void heapSort(List<StuInfo> stuInfosList) {
        //建堆
        buildHeap(stuInfosList);
        StuInfo student;
        for (int i = stuInfosList.size() - 1; i >= 1; i--) {
            //交换
            student = stuInfosList.get(i);
            stuInfosList.set(i, stuInfosList.get(0));
            stuInfosList.set(0, student);
            //堆调整
            heapfity(stuInfosList, 0, i - 1);
        }
    }

    /**
     * 堆调整
     */
    private void heapfity(List<StuInfo> stuInfosList, int index, int len) {
        int lchild = index * 2 + 1;
        int rchild = index * 2 + 2;

        StuInfo student;
        int temp = 0;

        if (lchild <= len && rchild <= len) {
            temp = stuInfosList.get(lchild).getSum() < stuInfosList.get(rchild).getSum() ? lchild : rchild;
        } else if (lchild <= len) {
            temp = lchild;
        } else if (rchild <= len) {
            temp = rchild;
        }
        //
        if (stuInfosList.get(temp).getSum() < stuInfosList.get(index).getSum()) {
            student = stuInfosList.get(temp);
            stuInfosList.set(temp, stuInfosList.get(index));
            stuInfosList.set(index, student);
        }
    }

    /**
     * 建立小根堆
     */
    private void buildHeap(List<StuInfo> stuInfosList) {
        for (int i = stuInfosList.size() / 2 - 1; i >= 0; i--) {
            heapfity(stuInfosList, i, stuInfosList.size() - 1);
        }
    }

希尔排序

/**
     * 希尔排序
     */
    private void shellSort(List<StuInfo> stuInfosList) {

        int step = stuInfosList.size() / 2;
        while (step >= 1) {

            for (int start = 0; start < step; start++) {
                insertSort(stuInfosList, step, start);
            }
            step /= 2;
        }
    }

    /**
     * 希尔排序循环内使用的插入排序
     */
    private void insertSort(List<StuInfo> stuInfosList, int step, int start) {
        //交换容器
        StuInfo student;
        for (int i = start + step; i < stuInfosList.size(); i += step) {
            for (int j = i; j - step >= 0 && stuInfosList.get(j).getSum() > stuInfosList.get(j - step).getSum(); j -= step) {
                student = stuInfosList.get(j);
                stuInfosList.set(j, stuInfosList.get(j - step));
                stuInfosList.set(j - step, student);
            }
        }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • javaWeb实现学生信息管理系统

    本文为大家分享了javaWeb实现学生信息管理系统,供大家参考,具体内容如下 初始版 初始版是没有加分页的.因为没怎么学过前端,界面很丑陋.主要技术:JSP,JavaBean,servlet,JDBC主要页面如下: 登录页面 主页 添加学生 查看所有学生 查询学生 工程目录 数据库 两个表,user表和student表.为了使用DBUtils工具,一定要注意数据库表的属性的命名和JavaBean的get(),set() 方法的匹配.比如t_user表里的uname,在JavaBean中是:pri

  • Java GUI实现学生成绩管理系统

    学习java有一年多了,一直在做web方面的练习,在一个项目中发现需要用到GUI的相关知识,结果没法做出来,网上这方面的文章又不是很多,所有只好自己硬着头皮从头再学一遍了,不过学习后发现,其实GUI是非常有趣的,他并不像WEB程序一样依赖互联网,而且还有许多布局和android相差不是很大,这才发现自己竟又爱上GUI的开发了,不多说了,直接上代码吧,相信有过android或相关界面开发的都明白这其中的道理. 先看看效果吧 1.登录主界面 package edu.gzu.stuManager; i

  • Java+Mysql学生管理系统源码

    最近正在学java和数据库,想起以前写的学生管理系统,都是从网上下载,敷衍了事.闲来无事,也就自己写了一个,不过功能实现的不是很多. 开发语言:java: 开发环境:Mysql, java: 开发工具:eclipse 开发此案例,首先得在电脑上有java开发环境和Mysql, java开发环境与Mysql的搭建,就不再叙述了,如果需要,请联系我最下面的联系方式:dingyelf@aliyun.com 此次系统比较简易:数据库中只有一个表:stu;功能:能够对学生增加.删除.修改. 开发步骤:  

  • Java实现学生成绩管理系统

    本文实例为大家分享了Java实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 新手练手小项目,主要练习面向对象.循环.数组.排序等等. 本人也是自学练手,代码有不正确的或不完善的也请多多包涵,留言指导. 感谢! 一.创建学生类 储存学生的基本信息 public class Student { private int no; private String name; Result result; public Student() { super(); } public Student(in

  • Java+MySQL实现学生信息管理系统源码

    基于Java swing+MySQL实现学生信息管理系统:主要实现JDBC对学生信息进行增删改查,应付一般课设足矣,分享给大家.(由于篇幅原因,代码未全部列出,如有需要留下邮箱) 鉴于太多同学要源码,实在发不过来,上传到github上 https://github.com/ZhuangM/student.git 1. 开发环境:jdk7+MySQL5+win7 代码结构:model-dao-view 2. 数据库设计--建库建表语句: CREATE DATABASE student; DROP

  • java实现学生成绩信息管理系统

    JAVA大作业:学生成绩管理系统(含有用户界面),供大家参考,具体内容如下 ps :多个包写在一起 package test; import java.awt.*; import java.awt.event.*; import javax.swing.*; import java.util.ArrayList; class person{ public String name; public String age; } class Student extends person{ public

  • java学生成绩管理系统设计与实现

    本文实例为大家分享了java学生成绩管理系统的具体代码,供大家参考,具体内容如下 /* *@copyright by LzyRapx on 2016/4/12. *@name:java学生成绩管理系统. *@功能:学生相关信息,录入,查询,统计,修改等.... *@PS:图形界面的学生管理系统不要求就不做了. */ import java.util.Scanner; import java.lang.*; import java.io.*; class Student { private sta

  • java学生信息管理系统源代码

    本文实例为大家分享了java学生信息管理系统的具体代码,实现学生信息: 增加 int[] a=new int[9] .删除 .查找.更改,供大家参考,具体内容如下 /*学生信息管理系统,实现学生信息: *增加 int[] a=new int[9] *删除 *查找 *更改 */ import java.util.Scanner;//导入java输入流 import java.lang.*; import java.io.*; class Student { private static Stude

  • Eclipse+Java+Swing实现学生成绩管理系统的实例代码

    一.系统介绍 本系统实现了用户登录,实现了对学生成绩的增删改查,实现了用户修改密码功能,采用MD5加密算法,数据库使用Mysql8.0.13,界面良好. 二.系统展示 1.登录页 2.主页面 3.查询学生成绩 4.修改学生成绩 5.添加学生成绩 6.修改系统密码 三.系统实现 Student.java package com.sjsq.model; import java.util.ArrayList; import java.util.List; /** * 学生实体类 * @author s

  • java学生管理系统界面简单实现(全)

    学生管理系统简单的实现,供初学Java Swing同学学习使用. import java.awt.Dimension; import java.awt.Toolkit; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JLabel; import jav

随机推荐