【C语言】C语言 学生成绩管理系统(源码+报告)【千行代码】【独一无二】

简介: 【C语言】C语言 学生成绩管理系统(源码+报告)【千行代码】【独一无二】

一、设计要求

学生成绩管理系统旨在提供一个高效且便捷的工具,用于管理学生、课程和选课信息,并生成和显示学生成绩单。系统主要包括以下功能模块:

数据初始化模块:读取学生、课程和选课信息表文件,初始化系统数据。

主菜单模块:显示主菜单,供用户选择操作。

学生信息管理模块:添加、修改、删除和查询学生信息。

课程信息管理模块:添加、修改、删除和查询课程信息。

选课信息管理模块:添加、修改、删除和查询选课信息。

成绩单管理模块:根据选课信息和课程信息生成学生成绩单,并支持显示和排序功能。

数据存储模块:将当前的学生信息、课程信息和选课信息保存到文件中。


👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 千行学生 ” 获取。👈👈👈


二、设计思路

程序的主要数据结构包括学生信息、课程信息、选课信息和成绩单信息,具体定义

typedef struct    //学生信息 
{   
    char xh[10];  //学号
  char xm[9];   //姓名,最多4个汉字
    char xb[3];   //性别
  int nl;       //年龄
}Student;

typedef struct    //课程信息
{
  char kh[8];   //课号
  char km[11];  //课名,最多5个汉字
    float xf;     //学分
}Course;

typedef struct    //选课信息
{
  char xh[10];  //学号
  char kh[8];   //课号
    float cj;     //成绩
}Select;


👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 千行学生 ” 获取。👈👈👈


Student:表示学生信息,包括学号、姓名、性别和年龄。

Course:表示课程信息,包括课号、课名和学分。

Select:表示选课信息,包括学号、课号和成绩。

Score:表示成绩单信息,包括学号、各门课程成绩、加权平均分和总学分。

这些数据结构用于存储和管理系统中的各类信息。


首先需要定义程序所需的数据结构、全局变量、常量以及各个函数。数据的定义包括学生信息、课程信息、选课信息和成绩单信息的结构体定义,以及用于操作这些数据的函数定义。

这些结构体定义描述了学生、课程、选课和成绩的相关信息。


1.Student 结构体:

xh :学号,用字符数组表示,长度为10。

xm :姓名,用字符数组表示,长度为9。注释提到最多4个汉字,但实际长度是9,可能是为了容纳更多的字符。

xb :性别,用字符数组表示,长度为3。通常只需要一个字符表示性别,这里可能是为了包含空字符(‘\0’)。

nl :年龄,用整型表示。


2.Course 结构体:

kh :课号,用字符数组表示,长度为8。

km :课名,用字符数组表示,长度为11。注释提到最多5个汉字,但实际长度是11,同样可能是为了容纳更多的字符。

xf :学分,用浮点数表示。


3.Select 结构体:

xh :学号,用字符数组表示,长度为10。

kh :课号,用字符数组表示,长度为8。

cj :成绩,用浮点数表示。


👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 千行学生 ” 获取。👈👈👈


4.Score 结构体:

xh :学号,用字符数组表示,长度为9。注释中长度为9,与其他结构体中的长度不同,可能是一个错误。

cj :课程成绩数组,用浮点数表示,长度为10。注释中说明不超过10门课程成绩。

pj :加权平均分,用浮点数表示。

zxf :总学分,用浮点数表示。

结构体可以用来表示学生、课程、选课和成绩信息,可以方便地进行相关数据的存储和操作,比如记录学生选课情况、计算学生的平均成绩等。


2.1 主菜单模块

主菜单模块提供用户界面,让用户可以选择各种操作。display_main_menu函数用于显示菜单并处理用户输入。

代码定义了一个函数 display_main_menu() ,用于显示学生成绩管理系统的主菜单,并返回用户选择的菜单项。函数通过一个 do-while 循环来实现,循环条件是用户输入的字符不在 ‘0’ 到 ‘5’ 的范围内。在循环体内,首先调用 system(“cls”) 清空控制台屏幕,然后使用 printf 输出主菜单选项以及作者信息。用户被提示选择一个菜单选项,并通过 getchar() 获取用户输入的字符,这个字符被存储在变量 c 中。若用户输入不在合法范围内,则继续显示主菜单直至输入正确为止。最后,函数返回用户选择的菜单项对应的整数值。


👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 千行学生 ” 获取。👈👈👈


该函数的设计简洁明了,通过循环确保了用户只能选择合法的菜单选项,防止了输入错误的情况。菜单项的显示清晰明了,包括了各种功能选项以及作者信息,使用户能够方便地了解系统功能并选择操作。

int display_main_menu()
{  
  char c;
  do
  {
    system("cls");
    printf("\n\n\t\t\t         学生成绩管理系统\n\n");
    printf("\t\t\t 1.修改或添加学生、课程和选课信息\n");
    printf("\t\t\t 2.显示学生、课程和选课信息\n");
    printf("\t\t\t 3.删除学生、课程和选课信息\n");
    printf("\t\t\t 4.查询学生、课程和选课信息\n");
    printf("\t\t\t 5.保存学生、课程和选课信息到文件\n");
    printf("\t\t\t 0.退出\n");
    printf("\t\t\t 软件作者 学号:032330135 姓名:南小航\n");
    printf("\n\t\t\t   请选择 (0~5):  ");
    fflush(stdin);
    c=getchar();
  }while (c<'0'||c>'5');
  return c-'0';
}


2. 2 学生信息管理模块

学生信息管理模块包含添加、修改、删除和查询学生信息的功能。

添加或修改学生信息 (input_stud):


这段代码定义了一个名为 input_stud 的函数,用于向学生信息数组中输入新的学生信息。函数接受两个参数:一个是存储学生信息的数组 slist ,另一个是当前已存在的学生数量 scount 。在函数内部,首先创建一个临时的 Student 结构体变量 temp 用于存储新输入的学生信息。然后,通过一系列 printf 和 scanf 语句,提示用户输入学号、姓名、性别和年龄,并将输入的信息存储到 temp 变量中。接着,使用 for 循环遍历已存在的学生信息数组,检查输入的学号是否已经存在于数组中。如果找到了相同学号的学生,则询问用户是否要覆盖已存在的学生信息,若用户选择覆盖,则更新对应位置的学生信息。如果输入的学号在数组中不存在,则将新的学生信息存储到数组的末尾,并将已存在的学生数量 scount 增加一。最后,函数返回更新后的学生数量 scount 。

int input_course(Course clist[], int ccount)
{ 
    Course temp;
    int i; 
    char yes;

    printf("请输入课号:");
    scanf("%s", temp.kh);
    printf("请输入课名:");
    scanf("%s", temp.km);
    printf("请输入学分:");
    scanf("%f", &temp.xf);

    for (i = 0; i < ccount; i++) {
        if (strcmp(clist[i].kh, temp.kh) == 0) {
            printf("课程已存在,是否覆盖(Y/N):");
            fflush(stdin);
            yes = getchar();
            if (yes == 'Y' || yes == 'y') {
                clist[i] = temp;
            }
            return ccount;
        }
    }

    clist[ccount++] = temp;

    return ccount;
}

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 千行学生 ” 获取。👈👈👈


2.3 显示课程信息

这段代码定义了一个名为 disp_stud 的函数,用于显示学生信息。函数接受两个参数:一个是存储学生信息的数组 slist ,另一个是当前已存在的学生数量 scount 。在函数内部,首先使用 printf 输出表头,包括学号、姓名、性别和年龄等字段。然后,通过 for 循环遍历学生信息数组,逐一输出每个学生的学号、姓名、性别和年龄。每个字段之间用制表符 \t 分隔,每个学生信息占据一行。最后,使用 system(“pause”) 函数暂停程序的执行,等待用户按下任意键继续。


void disp_stud(Student slist[], int scount) //显示学生信息
{
    int i;
    printf("学号\t姓名\t性别\t年龄\n");
    for (i = 0; i < scount; i++) {
        printf("%s\t%s\t%s\t%d\n", slist[i].xh, slist[i].xm, slist[i].xb, slist[i].nl);
    }
    system("pause");
}

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 千行学生 ” 获取。👈👈👈


2.4 删除课程信息

定义了一个名为 delete_course 的函数,用于删除课程信息数组中的某一门课程。函数接受两个参数:一个是存储课程信息的数组 clist ,另一个是当前已存在的课程数量 ccount 。在函数内部,首先声明了一些变量,包括用于存储用户输入课程号的字符数组 kh 、循环中的计数变量 i 和 j 、用于标记是否找到要删除的课程的标志变量 flag ,以及用于接收用户是否删除的字符 yes 。然后,通过 printf 提示用户输入要删除的课程号,并通过 scanf 获取用户输入的课程号。接着,通过 for 循环遍历课程信息数组,查找与用户输入的课程号匹配的课程。若找到匹配的课程,则提示用户找到课程信息,并询问用户是否删除该课程。若用户确认删除,则通过另一个嵌套的 for 循环将数组中该课程后面的所有课程向前移动一个位置,同时将课程数量减一,以实现删除操作。最后,根据是否找到课程,输出相应的提示信息,并通过 system(“pause”) 暂停程序的执行,等待用户按下任意键继续,最后返回更新后的课程数量 ccount 。

int delete_course(Course clist[], int ccount)  //删除课程信息
{   
    char kh[11]; 
    int i, j, flag = 0;
    char yes; 

    printf("请输入要删除的课程号:");
    scanf("%s", kh);

    for (i = 0; i < ccount; i++) {
        if (strcmp(clist[i].kh, kh) == 0) {
            printf("找到课程 %s %s %.1f,是否删除(Y/N):", clist[i].kh, clist[i].km, clist[i].xf);
            fflush(stdin);
            yes = getchar();
            if (yes == 'Y' || yes == 'y') {
                for (j = i; j < ccount - 1; j++) {
                    clist[j] = clist[j + 1];
                }
                ccount--;
                printf("删除成功\n");
            }
            flag = 1;
            break;
        }
    }
    if (!flag) {
        printf("未找到课程号为 %s 的课程\n", kh);
    }

    system("pause");
    return ccount;
}

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 千行学生 ” 获取。👈👈👈


2.5 成绩单管理模块

代码 略...


2.6 显示成绩单

定义了一个名为 disp_cjlist 的函数,用于显示成绩列表中每个学生的成绩情况。函数接受四个参数:一个是存储成绩信息的数组 cjlist ,一个是成绩列表中学生数量 cjcount ,另外两个是存储学生信息的数组 slist 以及学生数量 scount 。在函数内部,通过两个嵌套的 for 循环遍历成绩列表数组和学生信息数组,对每个学生进行处理。在内部循环中,首先比较学生学号,找到与成绩列表中学号匹配的学生信息,并输出学号和姓名。然后,通过另一个循环输出学生的课程成绩,以及加权平均分和总学分。在课程成绩输出时,限制最多输出10门课程的成绩,并且当成绩为0时停止输出。最后,通过 system(“pause”) 函数暂停程序的执行,等待用户按下任意键继续。

代码 略...


其他模块解释略…

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 千行学生 ” 获取。👈👈👈


三、可视化分析

主菜单


修改学生名单


修改课程信息

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 千行学生 ” 获取。👈👈👈


显示课程信息


显示学生信息


显示课程信息

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 千行学生 ” 获取。👈👈👈


显示成绩单


查询学生信息


查询成绩信息


删除学生信息

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 千行学生 ” 获取。👈👈👈


删除课程信息


保存到文件


👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “ 千行学生 ” 获取。👈👈👈

相关文章
|
14天前
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
90 9
|
13天前
|
存储 搜索推荐 算法
【数据结构】树型结构详解 + 堆的实现(c语言)(附源码)
本文介绍了树和二叉树的基本概念及结构,重点讲解了堆这一重要的数据结构。堆是一种特殊的完全二叉树,常用于实现优先队列和高效的排序算法(如堆排序)。文章详细描述了堆的性质、存储方式及其实现方法,包括插入、删除和取堆顶数据等操作的具体实现。通过这些内容,读者可以全面了解堆的原理和应用。
56 16
|
9天前
|
搜索推荐 算法 C语言
【排序算法】八大排序(上)(c语言实现)(附源码)
本文介绍了四种常见的排序算法:冒泡排序、选择排序、插入排序和希尔排序。通过具体的代码实现和测试数据,详细解释了每种算法的工作原理和性能特点。冒泡排序通过不断交换相邻元素来排序,选择排序通过选择最小元素进行交换,插入排序通过逐步插入元素到已排序部分,而希尔排序则是插入排序的改进版,通过预排序使数据更接近有序,从而提高效率。文章最后总结了这四种算法的空间和时间复杂度,以及它们的稳定性。
50 8
|
9天前
|
搜索推荐 算法 C语言
【排序算法】八大排序(下)(c语言实现)(附源码)
本文继续学习并实现了八大排序算法中的后四种:堆排序、快速排序、归并排序和计数排序。详细介绍了每种排序算法的原理、步骤和代码实现,并通过测试数据展示了它们的性能表现。堆排序利用堆的特性进行排序,快速排序通过递归和多种划分方法实现高效排序,归并排序通过分治法将问题分解后再合并,计数排序则通过统计每个元素的出现次数实现非比较排序。最后,文章还对比了这些排序算法在处理一百万个整形数据时的运行时间,帮助读者了解不同算法的优劣。
36 7
|
7天前
|
C语言 Windows
C语言课设项目之2048游戏源码
C语言课设项目之2048游戏源码,可作为课程设计项目参考,代码有详细的注释,另外编译可运行文件也已经打包,windows电脑双击即可运行效果
18 1
|
13天前
|
C语言
【数据结构】二叉树(c语言)(附源码)
本文介绍了如何使用链式结构实现二叉树的基本功能,包括前序、中序、后序和层序遍历,统计节点个数和树的高度,查找节点,判断是否为完全二叉树,以及销毁二叉树。通过手动创建一棵二叉树,详细讲解了每个功能的实现方法和代码示例,帮助读者深入理解递归和数据结构的应用。
62 8
|
10天前
|
程序员 C语言 开发者
pymalloc 和系统的 malloc 有什么区别?
pymalloc 和系统的 malloc 有什么区别?
|
C语言
c语言打字母游戏源码
c语言打字母游戏源码
135 0
|
1月前
|
C语言 C++
C语言 之 内存函数
C语言 之 内存函数
33 3
|
6天前
|
C语言
c语言调用的函数的声明
被调用的函数的声明: 一个函数调用另一个函数需具备的条件: 首先被调用的函数必须是已经存在的函数,即头文件中存在或已经定义过; 如果使用库函数,一般应该在本文件开头用#include命令将调用有关库函数时在所需要用到的信息“包含”到本文件中。.h文件是头文件所用的后缀。 如果使用用户自己定义的函数,而且该函数与使用它的函数在同一个文件中,一般还应该在主调函数中对被调用的函数做声明。 如果被调用的函数定义出现在主调函数之前可以不必声明。 如果已在所有函数定义之前,在函数的外部已做了函数声明,则在各个主调函数中不必多所调用的函数在做声明
21 6