学生信息管理系统
需求概述
编写一个可以对学生的成绩信息进行管理的系统,通过该系统可以实现对学生成绩的显示,排序,增删改查,保存载入并且统计出各科最高分和不及格人数
展示
总体设计
功能划分
密码登录模块
班级创建模块
学生信息录入模块
学生信息显示模块
学生信息查询模块
学生信息排序模块
学生信息统计模块
学生信息删除模块
学生信息新增模块
学生信息修改模块
学生信息保存模块
学生信息载入模块
系统退出模块
数据结构
学生结构体链表
包含学生的学号,姓名,成绩,总分,平均分,排名
程序流程
详细设计
头文件部分
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <conio.h>
结构体
#define N 30//最大容量
#define M 3//功课门数
typedef struct info
{
int sid;//学号
char name[20];//姓名
int score[M];//M门功课的成绩
double total;//总分
double aver;//平均分
int order;
}INFO;
typedef struct stu
{
INFO data;//数据域
struct stu *next;//指针域
}STU;
密码登录模块
int command,i,flag=0;//command为操作指令,i计数器,flag判断密码是否正确
char c, Password[6];
STU *h;
printf("请输入密码(3次机会)
");
for(i=0;i<3;i++)
{
int x=0;
while(x<5&&c!=13)//13是回车符的ASCII码
{
c=getch();
Password[x++]=c;
if(c!=13)
putchar('*');//输入的密码以*的形式显示
}
Password[x]='';
if(strcmp(Password,"12345")==0)
{
flag=1;
break;//如果密码正确则跳出循环
}
else
if(i==2)
printf("
密码错误!退出系统!");
else
printf("
密码错误!请输入正确密码:");
}
if(flag)
{
//进入系统
}
菜单显示
void showMenu()
{
printf("
密码正确!
");
printf("------学生信息管理系统V2.0--------
");
printf("* 1. 创建班级 *
");
printf("* 2. 学生信息录入 *
");
printf("* 3. 学生信息显示 *
");
printf("* 4. 学生信息查询 *
");
printf("* 5. 学生信息排序 *
");
printf("* 6. 学生信息统计 *
");
printf("* 7. 学生信息删除 *
");
printf("* 8. 学生信息新增 *
");
printf("* 9. 学生信息修改 *
");
printf("* 10. 学生信息保存 *
");
printf("* 11.学生信息载入 *
");
printf("* 0. 退出系统 *
");
printf("----------------------------------
");
printf("* 作者:,学号:xxxx *
");
printf("----------------------------------
");
}
班级创建模块
printf("请输入需要创建的班级人数:");
scanf("%d",&count);//count为全局变量
printf("初始化班级人数为%d人
",count);
学生信息录入模块
STU *createClass(int n)//n为要创建的个数
{
STU *p,*q,*h;//h为头指针,p指向新创建的学生,q指向最后一个学生
int i;
for(i=0;i<n;i++)
{
p=(STU *)malloc(sizeof(STU));
printf("请输入第%d个学生的学号、姓名、语数英成绩:",i+1);
scanf("%d%s%d%d%d",&p->data.sid,p->data.name,&p->data.score[0],&p->data.score[1],&p->data.score[2]);
p->data.total=p->data.score[0]+p->data.score[1]+p->data.score[2];
p->data.aver=p->data.total/M;
p->data.order=0;
p->next=NULL;
if(i==0)
h=p;//将头指针固定在链表头部
else
q->next=p;//将链表末尾和新创建的学生连接起来
q=p;//q指针指向新创建的学生即链表的末尾
}
return h;//返回头指针
}
学生信息显示模块
void showStuInfo(STU *h)//h为头指针
{
STU *p;
p=h