广告
返回顶部
首页 > 资讯 > 后端开发 > Python >java实现学生成绩档案管理系统
  • 595
分享到

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

2024-04-02 19:04:59 595人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

本文实例为大家分享了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);
            }
        }
}

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

--结束END--

本文标题: java实现学生成绩档案管理系统

本文链接: https://www.lsjlt.com/news/131092.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • java实现学生成绩档案管理系统
    本文实例为大家分享了java实现学生成绩档案管理系统的具体代码,供大家参考,具体内容如下 实验要求 • 学生信息录入,信息包括学号、姓名、专业、四门课成绩、总分、名次; ...
    99+
    2022-11-12
  • java实现简单学生成绩档案管理系统
    本文实例为大家分享了java学生成绩档案管理系统的具体代码,供大家参考,具体内容如下 学生成绩档案管理系统源代码: student public class students{   ...
    99+
    2022-11-13
  • java怎么实现简单学生成绩档案管理系统
    今天小编给大家分享一下java怎么实现简单学生成绩档案管理系统的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。学生成绩档案管理...
    99+
    2023-06-30
  • Java实现学生成绩管理系统
    本文实例为大家分享了Java实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 新手练手小项目,主要练习面向对象、循环、数组、排序等等。 本人也是自学练手,代码有不正确的或不完...
    99+
    2022-11-12
  • 学生成绩管理系统——JAVA
    学生成绩管理系统 1.简介 本学生成绩管理系统具有录入学生成绩、查询学生成绩、输出学 生按成绩的排名、输出学科的分数四个功能,其中后两个功能在“输出成绩”这一目录下。 此系统可以实现学生成绩管理的一些...
    99+
    2023-10-01
    java mysql 数据库 计算机视觉 爬虫
  • Java——学生成绩管理系统
    一、项目简介 学生管理系统是一种基于计算机技术实现的学生信息管理工具,能够方便地对学生信息进行录入、查询、修改和删除。该项目采用 Java 语言编写,使用 Spring MVC 框架和 MySQL 数据库,实现了以上所述的主要功能,该学生管...
    99+
    2023-09-08
    mysql 数据库 开发语言 json
  • java实现简单学生成绩管理系统
    本文实例为大家分享了java实现学生成绩管理系统的具体代码,供大家参考,具体内容如下   import java.util.Scanner; import java.lang.*;...
    99+
    2022-11-13
  • C#实现学生成绩管理系统
    本文实例为大家分享了C#实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 使用链表写学生成绩管理系统 链表可以灵活的展示增删改查 下面是结果演示 这是登录及部分添加 继续添...
    99+
    2022-11-13
    C#学生成绩管理系统 C#成绩管理系统 C#学生管理系统
  • python mysql实现学生成绩管理系统
    这学期在学python,感觉想写一个东西来巩固自己的基础,因为大二的时候我看过python,所以还是一共花了几个小时写了一个基于mysql的成绩管理系统,这个东西其实拿不出手,不过就...
    99+
    2022-11-12
  • C++实现学生档案管理系统
    本文实例为大家分享了C++实现学生档案管理系统的具体代码,供大家参考,具体内容如下 课题描述: 1.为学生档案管理人员编写一个学生档案管理系统 ,用菜单选择方式完成下列功能: 2.学...
    99+
    2022-11-13
  • C++实现简单学生成绩管理系统
    本文实例为大家分享了C++实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 一、问题描述 设计一个学生成绩管理程序,实现按班级完成对学生成绩信息的录入和修改,并用文件保存。实...
    99+
    2022-11-13
  • C#实现简单学生成绩管理系统
    本文实例为大家分享了C#实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 C#作业 用循环结构/数组实现 进入启动页面 管理员身份登入 用户名:师晓峰密码:88481234...
    99+
    2022-11-13
    C#学生成绩管理系统 C#学生管理系统 C#成绩管理系统
  • shell如何实现学生成绩管理系统
    这篇文章主要介绍了shell如何实现学生成绩管理系统,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体内容如下基本的操作增加删除查询展示全部学生信息vim编辑保存信息的文件遇...
    99+
    2023-06-09
  • MySQL学生成绩管理的系统
    目录 第一章 系统总体设计 1.1 项目背景及意义 1.2 系统的设计内容 1.3 开发环境 第二章 需求分析 2.1 系统业务需求 2.2 系统数据需求 第三章 概要设计 3.1 功能结构设计 3...
    99+
    2023-09-22
    mysql
  • C++实现学生成绩管理系统最新版
    学生成绩管理系统,供大家参考,具体内容如下 一、问题描述及功能要求 (1)输入同学的学号,姓名,三门科成绩(应用数学、大学英语、计算机应用基础) (2)可以计算出每个学生三门课的...
    99+
    2022-11-12
  • python实现简单的学生成绩管理系统
    本文实例为大家分享了python实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 需求: 代码: import os filename = 'student.txt' d...
    99+
    2022-11-13
  • C++实现简单的学生成绩管理系统
    本文实例为大家分享了C++实现简单学生成绩管理系统的具体代码,供大家参考,具体内容如下 manage.h #include <iostream> #include <...
    99+
    2022-11-13
  • Java基础——学生成绩信息管理系统(简单实现)
    需求 1、 定义一个学生类 Student,包含姓名、成绩信息; 2、使用 ArrayList集合存储学生对象; 3、 对集合中的元素进行增删查改的操作。 一、定义学生类 学生类可以包含姓名、成绩、学号、年龄等等,这里...
    99+
    2023-10-20
    java 开发语言 后端
  • 怎么使用java实现简单学生成绩管理系统
    这篇文章将为大家详细讲解有关怎么使用java实现简单学生成绩管理系统,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体内容如下 import java.util.Scanner;imp...
    99+
    2023-06-29
  • C语言实现学生档案管理系统
    本文实例为大家分享了C语言实现学生档案管理系统的具体代码,供大家参考,具体内容如下     #include<stdio.h&...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作