1. 题目分析
对学生信息管理系统,要求完成以下基本任务:
1.改写程序为良好程序风格(文档注释,函数注释,语句注释)。
2.将功能补充完全(基于文件处理,完成刷新和保存功能)。
3.将学生信息改为更好的数据组织,而非离散形式(结构体)。
实验目的
1、 明确结构化程序设计的基本结构;
2、 通过对问题的分析,设计合理的结构化程序解决问题。
2. 关键算法构造
学生管理系统有九大功能,分别是帮助、读入、查询、修改、增加、删除、显示、保存以及退出,要实现这些功能,可以按以下步骤进行:
第一步:建立学生信息结构体;
第二步:分别写出帮助、读入、查询、修改、增加、删除、显示、保存这些部分的函数;
第三步:写出菜单函数,在函数中调用第二步中的函数体,使用户可以选择所需功能进行操作;
第四步:在主函数中调用菜单函数,实现程序功能。
流程图:
3. 程序实现
#include<stdio.h> /*I/O函数*/
#include<stdlib.h> /*其它说明*/
#include<string.h> /*字符串函数*/
#define LEN 15 /* 学号和姓名最大字符数,实际请更改*/
#define N 100 /* 最大学生人数,实际请更改*/
struct record
{
char code[LEN+1]; /* 学号*/
char name[LEN+1]; /* 姓名*/
int age; /* 年龄*/
char sex; /* 性别*/
float score[3]; /* 3门课程成绩*/
}stu[N];
int k=1,n=0, m=0; /*定义全局变量,n代表当前记录的学生总人数,m为新增加的学生人数*/
void readfile(); /*读入数据*/
void seek(); /*查找*/
void modify(); /*修改数据*/
void insert(); /*插入数据*/
void del(); /*删除数据*/
void display(); /*显示信息*/
void save(); /*保存信息*/
void menu(); /*用户界面*/
void help(); /*帮助*/
int main()
{
while(k)
{
menu();
}
//system("pause");
return 0;
}
void help() /*帮助系统*/
{
printf("\n0.欢迎使用系统帮助!\n");
printf("\n1.初次进入系统后,请先从文件中读入学生信息,如果文件不存在或文件中无内容,请选择增加学生信息;\n");
printf("\n2.按照菜单提示键入数字代号;\n");
printf("\n3.增加学生信息后,切记保存;\n");
printf("\n4.谢谢您的使用!\n");
system("pause"); /*发出一个DOS命令,屏幕上输出“请按任意键继续”*/
}
void readfile() /*从文件中读入数据,建立信息*/
{
char filename[LEN+1]; /*文件名*/
FILE * fp; /*文件指针*/
int i=0;
printf("请输入已有学生信息的文件名:\n");
scanf("%s",filename);
if((fp=fopen(filename,"r"))==NULL) /*以只读方式打开指定文件*/
{
printf("打开文件%s出错!",filename);
printf("您需要先选择菜单4增加学生信息,并注意及时保存");
system("pause");
return;
}
while(fscanf(fp,"%s %s %d %c %f %f %f",stu[i].code,stu[i].name,&stu[i].age,&stu[i].sex,&stu[i].score[0],&stu[i].score[1],&stu[i].score[2])==7)
{ /*循环录入学生信息*/
i++;
}
n=i;
if(0==i) printf("文件为空,请选择菜单4增加学生信息,并及时保存\n");
else printf("读入完毕\n");
fclose(fp);
system("pause");
}
void seek() /*按学号或姓名查找学生信息*/
{
int i,item,flag;
char s1[21]; /* 以姓名和学号最长长度+1为准*/
printf("------------------\n");
printf("-----1.按学号查询-----\n");
printf("-----2.按姓名查询-----\n");
printf("-----3.退出本菜单-----\n");
printf("------------------\n");
while(1)
{
printf("请选择子菜单编号:");
scanf("%d",&item);
flag=0;
switch(item)
{
case 1:
printf("请输入要查询的学生的学号:\n");
scanf("%s",s1);
for(i=0;i<n;i++)
if(strcmp(stu[i].code,s1)==0)
{
flag=1;
printf("学生学号 学生姓名 年龄 性别 C语言成绩 高等数学 大学英语成绩\n");
printf("--------------------------------------------------------------------\n");
printf("%6s %7s %6d %6c %9.1f %10.1f %10.1f\n",stu[i].code,stu[i].name,stu[i].age,
stu[i].sex,stu[i].score[0],stu[i].score[1],stu[i].score[2]);
break;
}
if(0==flag)
printf("该学号不存在!\n"); break;
case 2:
printf("请输入要查询的学生的姓名:\n");
scanf("%s",s1);
for(i=0;i<n;i++)
if(strcmp(stu[i].name,s1)==0)
{
flag=1;
printf("学生学号 学生姓名 年龄 性别 C语言成绩 高等数学 大学英语成绩\n");
printf("--------------------------------------------------------------------\n");
printf("%6s %7s %6d %6c %9.1f %10.1f %10.1f\n",stu[i].code,stu[i].name,stu[i].age,
stu[i].sex,stu[i].score[0],stu[i].score[1],stu[i].score[2]);
}
if(0==flag)
printf("该姓名不存在!\n"); break;
case 3:return;
default:printf("请在1-3之间选择\n");
}
}
}
void modify() /*修改学生信息*/
{
int i,item,num=-1; /*item表示选择修改的子菜单编号,num保存要修改信息的学生的序号*/
char sex1,s1[LEN+1],s2[LEN+1]; /* 以姓名和学号最长长度+1为准*/
float score1;
printf("请输入要要修改的学生的学号:\n");
scanf("%s",s1);
for(i=0;i<n;i++)
if(strcmp(stu[i].code,s1)==0) /*比较字符串是否相等*/
num=i;
if(num!=-1)
{
printf("------------------\n");
printf("1.修改姓名\n");
printf("2.修改年龄\n");
printf("3.修改性别\n");
printf("4.修改C语言成绩\n");
printf("5.修改高等数学成绩\n");
printf("6.修改大学英语成绩\n");
printf("7.退出本菜单\n");
printf("------------------\n");
while(1)
{
printf("请选择子菜单编号:");
scanf("%d",&item);
switch(item)
{
case 1:
printf("请输入新的姓名:\n");
scanf("%s",s2);
strcpy(stu[num].name,s2); break;
case 2:
printf("请输入新的年龄:\n");
scanf("%d",stu[num].age);break;
case 3:
printf("请输入新的性别:\n");
scanf("%c",&sex1);
stu[num].sex=sex1; break;
case 4:
printf("请输入新的C语言成绩:\n");
scanf("%f",&score1);
stu[num].score[0]=score1; break;
case 5:
printf("请输入新的高等数学成绩:\n");
scanf("%f",&score1);
stu[num].score[1]=score1; break;
case 6:
printf("请输入新的大学英语成绩:\n");
scanf("%f",&score1);
stu[num].score[2]=score1; break;
case 7: return;
default:printf("请在1-7之间选择\n");
}
}
printf("修改完毕,显示结果请选择菜单6,并及时保存\n");
}
else
{
printf("该学号不存在\n");
system("pause");
}
}
void sort()/*按学号排序*/
{
int i,j,k,*p,*q,s;
char temp[LEN+1],ctemp;
float ftemp;
for(i=0;i<n-1;i++) /*比较法排序*/
{
for(j=n-1;j>i;j--)
if(strcmp(stu[j-1].code,stu[j].code)>0)
{
strcpy(temp,stu[j-1].code);
strcpy(stu[j-1].code,stu[j].code);
strcpy(stu[j].code,temp);
strcpy(temp,stu[j-1].name);
strcpy(stu[j-1].name,stu[j].name);
strcpy(stu[j].name,temp);
ctemp=stu[j-1].sex;
stu[j-1].sex=stu[j].sex;
stu[j].sex=ctemp;
p=&stu[j-1].age;
q=&stu[j].age;
s=*q;
*q=*p;
*p=s;
for(k=0;k<3;k++)
{
ftemp=stu[j-1].score[k];
stu[j-1].score[k]=stu[j].score[k];
stu[j].score[k]=ftemp;
}
}
}
}
void insert() /*新增学生信息*/
{
int i=n,j,flag; /*n为现有学生人数*/
printf("请输入待增加的学生数:\n");
scanf("%d",&m);
if(m>0)
{
do
{
flag=1;
while(flag)
{
flag=0;
printf("请输入第%d位学生的学号:\n",i+1);
scanf("%s",stu[i].code);
for(j=0;j<i;j++)
if(strcmp(stu[i].code,stu[j].code)==0)
{
printf("已有该学号,请检查后重新输入\n");
flag=1;
break;
}
}
printf("请输入第%d 个学生的姓名:\n",i+1);
scanf("%s",stu[i].name);
printf("请输入第%d 个学生的年龄:\n",i+1);
scanf("%d",&stu[i].age);
printf("请输入第%d 个学生的性别:\n",i+1);
scanf(" %c",&stu[i].sex);
printf("请输入第%d 个学生的C语言成绩\n",i+1);
scanf("%f",&stu[i].score[0]);
printf("请输入第%d 个学生的高等数学成绩:\n",i+1);
scanf("%f",&stu[i].score[1]);
printf("请输入第%d 个学生的大学英语成绩:\n",i+1);
scanf("%f",&stu[i].score[2]);
if(0==flag)
{
i++;
}
}while(i<n+m);
}
n+=m;
printf("信息增加完毕,显示结果请选择菜单6,请及时保存!\n\n");
sort();
system("pause");
}
void del() /*按学号删除学生信息*/
{
int i,j,flag=0;
char s1[LEN+1];
printf("请输入要删除学生的学号:\n");
scanf("%s",s1);
for(i=0;i<n;i++)
if(strcmp(stu[i].code,s1)==0)
{
flag=1;
for(j=i;j<n-1;j++)
stu[j]=stu[j+1];
}
if(flag==0)
printf("该学号不存在!\n");
if(flag==1)
{
printf("删除成功,显示结果请选择菜单6,请及时保存\n");
n--;
}
system("pause");
}
void display() /*显示所有学生信息*/
{
int i;
printf("共有%d位学生的信息:\n",n);
if(0!=n)
{
printf("学生学号 学生姓名 年龄 性别 C语言成绩 高等数学 大学英语成绩\n");
printf("--------------------------------------------------------------------\n");
for(i=0;i<n;i++)
{
printf("%7s %7s %6d %6c %9.1f %10.1f %10.1f\n",stu[i].code,stu[i].name,stu[i].age,
stu[i].sex,stu[i].score[0],stu[i].score[1],stu[i].score[2]);
}
}
}
void save() /*保存数据*/
{
int i;
FILE * fp;
char filename[LEN+1];
printf("请输入欲将学生信息写入的文件名:\n");
scanf("%s",filename);
fp=fopen(filename,"w");
for(i=0;i<n;i++)
{
fprintf(fp,"%s %s %d %c %.1f %.1f %.1f\n",stu[i].code,stu[i].name,stu[i].age,stu[i].sex,stu[i].score[0],stu[i].score[1],stu[i].score[2]);
}
printf("保存成功\n");
fclose(fp);
system("pause");
}
void menu()/* 界面*/
{
int num;
printf(" \n\n \n\n");
printf(" ******************************************************\n\n");
printf(" * 学生信息管理系统 *\n \n");
printf(" ******************************************************\n\n");
printf("*********************系统功能菜单************************* \n");
printf(" ---------------------- ---------------------- \n");
printf(" ********************************************* \n");
printf(" * 0.系统帮助及说明 * * 1.读入学生信息 * \n");
printf(" ********************************************* \n");
printf(" * 2.查询学生信息 * * 3.修改学生信息 * \n");
printf(" ********************************************* \n");
printf(" * 4.增加学生信息 * * 5.按学号删除信息 * \n");
printf(" ********************************************* \n");
printf(" * 6.显示当前信息 * * 7.保存当前学生信息* \n");
printf(" ********************** ********************** \n");
printf(" * 8.退出系统 * \n");
printf(" ********************** \n");
printf(" ---------------------- ---------------------- \n");
printf("请选择菜单编号:");
scanf("%d",&num);
switch(num)
{
case 0:help();break;
case 1:readfile();break;
case 2:seek();break;
case 3:modify();break;
case 4:insert();break;
case 5:del();break;
case 6:display();break;
case 7:save();break;
case 8:k=0;break;
default:printf("请在0-8之间选择\n");
}
}
4. 调试、测试及运行结果
程序调试截图:
程序测试截图 :
在程序测试中可以看出,当增加学生信息并且选择保存之后,存放源程序的文件夹会有相应的文本文件生成,其中保存着输入的学生信息。
5、经验归纳
本次上机题目是结构化程序设计,目的是让我们掌握并且会熟练运用结构化设计这一方法,学生管理系统里,学生的信息使用结构体来存放,在程序编写过程中,我参照课本的学生管理系统,编译没有问题,程序可以运行,但是结果存在一些问题,在输入学生姓名和性别时,使用汉字输入会导致之后的成绩输入出现问题。在输入学生信息并且保存之后,会自动生成文件来存放数据,程序虽然完成了但是还有需要修改的地方,我通过这次上机也更加巩固了结构化程序的设计方法。