学生宿舍管理软件C语言源代码完整版Word文档格式.docx
《学生宿舍管理软件C语言源代码完整版Word文档格式.docx》由会员分享,可在线阅读,更多相关《学生宿舍管理软件C语言源代码完整版Word文档格式.docx(29页珍藏版)》请在冰点文库上搜索。
向程序中添加三条记录
按照先后顺序分别输入:
学生姓名:
张三,学生学号:
20070001,宿舍号:
502
学生姓名:
李四,学生学号:
20070003,宿舍号:
王五,学生学号:
20070002,宿舍号:
503
对功能2(修改学生信息)的测试:
修改学生王五的信息
王五,学生姓名:
20070005,宿舍号:
501
对功能3(删除学生信息)的测试:
删除学生李四的信息
输入:
李四
对功能4(以姓名查询学生信息)的测试:
查询学生王五的信息
王五
对功能5(以学号查询学生信息)的测试:
查询学号为20070001的信息
学生学号:
20070001
对功能6(以寝室号查询学生信息)的测试:
查询寝室号为501的信息
寝室号:
对功能7(按照寝室号从小到大的排序)和功能9(显示所有学生信息)的测试:
先选择功能7,然后选择功能9,观察显示出来的记录是否按照寝室号从小到大排序。
对功能8(按照学号从小到大的排序)和功能9(显示所有学生信息)的测试:
先选择功能8,然后选择功能9,观察显示出来的记录是否按照学号从小到大排序。
对功能10(保存操作)和功能11(加载记录)的测试:
先选择功能10,然后关闭程序,重新运行,此时选择功能11,然后选择功能9显示出学生信息,查看信息是否有错误。
二、概要设计
1.抽象数据类型:
ADTStudent{
数据对象:
D={ai,bi,ci,|ai∈charS[31],bi∈charA[16],ci,∈int,i=1,2,3,….}
数据关系:
R={<
(ai,bi,ci),(ai+1,bi+1,ci+1)>
|(ai,bi,ci)∈D,i=1,2,3,….}
基本操作:
S_number_Judge(StudentS,intt)
初始条件:
表S已存在
操作结果:
判断所输入学号在表中是否已存在
Add(StudentS)
初始条件:
操作结果:
向表S中插入一个记录
Alter(StudentS)
初始条件:
操作结果:
修改表S中的一条记录
Delete(StudentS)
删除表S中的一条记录
Display_All(StudentS)
显示表中所有学生的信息
Sort_D_number(StudentS)
表中记录按照寝室号从小到大排序
Sort_S_number(StudentS)
表中记录按学号从小到大排序
Query_S_name(StudentS)
根据所输入的学生姓名显示出该学生的信息
Query_S_number(StudentS)
根据所输入的学号显示出该学生的信息
Query_D_number(StudentS)
根据所输入的寝室号显示出该寝室的学生的信息
Save(StudentS)
将表中数据保存的文件中去
Load(StudentS)
将文件中数据加载到程序中
Judge_Save(inti,StudentS)
表中数据改变后没有及时保存在退出程序时提醒用户是否保存
}ADTStudent
2.本程序所包含的15个函数为:
(1).主函数main();
(2).菜单函数Menu();
(3).判断学号是否重复函数S_number_Judge(StudentS,intt);
(4).添加学生信息函数Add(StudentS);
(5).修改学生信息函数Alter(StudentS);
(6).删除学生信息函数Delete(StudentS);
(7).显示所有学生信息函数Display_All(StudentS);
(8).按照寝室号从小到大排序函数Sort_D_number(StudentS);
(9).按照学号从小到大排序函数Sort_S_number(StudentS);
(10).根据学生姓名查找函数Query_S_name(StudentS);
(11).根据学生学号查找函数Query_S_number(StudentS);
(12).根据寝室号查找函数Query_D_number(StudentS)
(13).存储函数Save(StudentS);
(14).加载函数Load(StudentS);
(15).判断在退出程序时是否保存函数Judge_Save(inti,StudentS);
各函数之间的调用关系如下:
3.N-S流程图
调用Menu()
输入i值
i==1
YN
Add(S)
Yi==2N
Alter(S)
i==3
Delete(S)
i==4
Query_S_name(S)
i==5
Query_S_number(S)
i==6
Query_D_number(S)
i==7
Sort_D_number(S)
i==8
Sort_S_number(S)
i==9
Display_All(S)
i==10
Save(S)
i==11
Load(S)
i==12
Judge_Save(dirty,S)
输出:
选择错误,请在数字1-12中选择
直到i==12
三、详细设计
源程序代码:
#include<
stdio.h>
string.h>
stdlib.h>
#defineM100
intdirty=0;
//用来判断是否已保存操作
//定义一个存储学生相关信息的结构体
typedefstruct
{
charS_name[31];
//学生姓名
charS_class[31];
//学生班级
charS_number[16];
//学生学号
intD_number;
//学生所在寝室的宿舍号
charS_address[500];
//学生地址
intS_phone[20];
//学生电话号码
intTotal;
//学生总数
}Student[M],St;
//判断学号是否与表中所存学号重复
voidS_number_Judge(StudentS,intt)
inti;
for(i=1;
i<
=(S->
Total)-1;
i++)
while(strcmp(S[i].S_number,S[t].S_number)==0)
{
printf("
学号输入失败,该学号已存在,请重新输入学号!
\n"
);
请输入学生的学号(15个字符以内):
"
scanf("
%s"
S[t].S_number);
getchar();
i=1;
}
}
//添加学生信息函数
voidAdd(StudentS)
printf("
请输入学生姓名(30个字符以内):
S[++(S->
Total)].S_name);
getchar();
//获取换行符
printf(“请输入学生班级(30个字符以内):
”);
S[S->
Total].S_class);
Total].S_number);
S_number_Judge(S,S->
Total);
//判断输入的学号是否与表中所存在的学号重复
请输入宿舍号码:
%d"
&
S[S->
Total].D_number);
请输入学生地址:
Total].S_address);
printf(“请输入学生电话号码:
Total].S_phone);
dirty=1;
添加成功!
\n\n"
//修改学生信息函数
voidAlter(StudentS)
intflag=0;
//用来判断表中是否存在所要修改的学生的信息
charname[20];
请输入你要修改学生的姓名:
name);
=S->
Total;
if(strcmp(S[i].S_name,name)==0)
flag=i;
if(!
flag)
printf("
你所要修改的学生信息在表中不存在!
else
{
新信息如下:
scanf("
S[flag].S_name);
getchar();
S[flag].S_class);
S[flag].S_number);
S_number_Judge(S,flag);
请输入宿舍号:
S[flag].D_number);
S[flag].S_address);
S[flag].S_phone);
dirty=1;
修改成功!
}
putchar('
\n'
//删除学生信息
voidDelete(StudentS)
inti,j;
//用来判断表中是否存在所要删除的学生的信息
请输入你要删除学生的姓名:
你所要删除的学生在表中不存在!
for(i=flag;
S->
j=i+1;
strcpy(S[i].S_name,S[j].S_name);
strcpy(S[i].S_number,S[j].S_number);
S[i].D_number=S[j].D_number;
(S->
Total)--;
删除成功!
//显示所有学生信息函数
voidDisplay_All(StudentS)
全体学生信息如下:
学生姓名学生班级学生学号宿舍号学生地址学生电话号码\n"
%-20s%-20s%-15s%-5d%s-10%s\n"
S[i].S_name,S[i].S_class,S[i].S_number,S[i].D_number,S[i].S_address,S[i].S_phone);
\n\n'
//排序函数按照寝室号从小到大排序(冒泡法)
voidSort_D_number(StudentS)
inti,j,t;
charname[30];
charnumber[15];
charaddress[300];
charCnumber[30];
for(j=i;
j<
j++)
if(S[i].D_number>
S[j].D_number)
{
strcpy(name,S[i].S_name);
strcpy(number,S[i].S_number);
strcpy(address,S[i].S_address);
strcpy(Cnumber,S[i].S_class);
t=S[i].D_number;
strcpy(S[i].S_name,S[j].S_name);
strcpy(S[i].S_number,S[j].S_number);
strcpy(S[i].S_address,S[j].S_address);
;
strcpy(S[i].S_class,S[j].S_class);
S[i].D_number=S[j].D_number;
strcpy(S[j].S_name,name);
strcpy(S[j].S_number,number);
strcpy(S[j].S_address,address);
strcpy(S[j].S_class,Cnumber);
S[j].D_number=t;
}
//排序函数按照学号从小到大排序(冒泡法)
voidSort_S_number(StudentS)
if(strcmp(S[i].S_number,S[j].S_number)>
0)
//排序函数按照班级号从小到大排序(冒泡法)
voidSort_S_class(StudentS)
if(strcmp(S[i].S_class,S[j].S_class)>
t=S[i].D_number;
S[i].D_number=S[j].D_number;
S[j].D_number=t;
//查询函数以班级为关键字进行查询(顺序查找)
voidQuery_S_class(StudentS)
inti,j=0;
charclassnumber[31];
请输入你要查找的班级号(30个字符以内):
classnumber);
所查找学生信息如下:
学生姓名学生班级学生学号宿舍号学生地址学生电话号码\n"
if(strcmp(classnumber,S[i].S_class)==0)
S[i].S_name,S[i].S_class,S[i].S_number,S[i].D_number,S[i].S_address,S[i].S_phone);
j=1;
j)
\n查找失败,表中不存在该学生的信息!
//查询函数以姓名为关键字进行查询(顺序查找)
voidQuery_S_name(StudentS)
charname[31];
请输入你要查找的学生的姓名(30个字符以内):
if(strcmp(name,S[i].S_name)==0)
//查询函数以学号为关键字进行查询(折半查找)
voidQuery_S_number(StudentS)
inti,j,top,base,mid;
j=0;
base=1;
top=S->
print