实验5宿舍管理系统Word格式文档下载.docx
- 文档编号:5796943
- 上传时间:2023-05-05
- 格式:DOCX
- 页数:18
- 大小:53.29KB
实验5宿舍管理系统Word格式文档下载.docx
《实验5宿舍管理系统Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《实验5宿舍管理系统Word格式文档下载.docx(18页珍藏版)》请在冰点文库上搜索。
}Stu,*St;
3.模块划分
(1)添加学生信息:
voidAdd(StS)
(2)判断学生学号是否重复:
voidS_number_Judge(StS,intt)
(3)修改学生信息:
voidAlter(StS)
(4)删除学生信息:
voidDelete(StS)
(5)显示所有学生信息:
voidDisplay_All(StS)
(6)按照寝室号从小到大排序:
voidSort_D_number(StS)
(7)按照学号从小到大排序:
voidSort_S_number(StS)
(8)以姓名为关键字查找:
voidQuery_S_name(StS)
(9)以学号为关键字进行查找:
oidQuery_S_number(StS)
(10)以寝室号为关键字进行查找:
voidQuery_D_number(StS)
(11)查找操作二级菜单:
voidSearch(StS)
(12)存储函数:
voidSave(StS)
(13)加载函数:
voidLoad(StS)
(14)判断是否存储过:
voidJudge_Save(inti,StS)
(15)一级菜单:
voidMenu()
(16)主函数:
voidmain()
4.详细设计
#include<
stdio.h>
string.h>
stdlib.h>
#defineM100
intchange=0;
//用来判断是否已保存操作
//定义一个存储学生相关信息的结构体
//判断学号是否与表中所存学号重复
inti;
for(i=1;
i<
=(S->
Total)-1;
i++)
{
if(i!
=t)
{
while((strcmp((S->
student[i]).S_number,(S->
student[t]).S_number)==0)&
&
(i!
=t))
printf("
学号输入失败,该学号已存在,请重新输入学号!
\n"
);
请输入学生的学号(15个字符以内):
"
scanf("
%s"
(S->
student[t]).S_number);
getchar();
i=1;
}
}
}
//添加学生信息函数
{
printf("
请输入学生姓名(30个字符以内):
student[++(S->
Total)]).S_name);
getchar();
//获取换行符
student[S->
Total]).S_number);
S_number_Judge(S,S->
Total);
//判断输入的学号是否与表中所存在的学号重复
请输入宿舍号码:
%d"
&
(S->
Total]).D_number);
change=1;
添加成功!
\n\n"
//修改学生信息函数
intflag=0;
//用来判断表中是否存在所要修改的学生的信息
charname[20];
请输入你要修改学生的姓名:
name);
=S->
Total;
if(strcmp((S->
student[i]).S_name,name)==0)
flag=i;
if(!
flag)
printf("
你所要修改的学生信息在表中不存在!
else
新信息如下:
scanf("
student[flag]).S_name);
getchar();
student[flag]).S_number);
S_number_Judge(S,flag);
请输入宿舍号:
student[flag]).D_number);
change=1;
修改成功!
putchar('
\n'
//删除学生信息
inti,j;
//用来判断表中是否存在所要删除的学生的信息
请输入你要删除学生的姓名:
你所要删除的学生在表中不存在!
for(i=flag;
S->
j=i+1;
strcpy((S->
student[i]).S_name,(S->
student[j]).S_name);
student[j]).S_number);
(S->
student[i]).D_number=(S->
student[j]).D_number;
Total)--;
删除成功!
//显示所有学生信息函数
全体学生信息如下:
学生姓名学生学号宿舍号\n"
%-20s%-15s%-5d\n"
student[i]).D_number);
\n\n'
//排序函数按照寝室号从小到大排序(冒泡法)
inti,j,t;
charname[30];
charnumber[15];
for(j=i;
j<
j++)
if((S->
student[i]).D_number>
student[j]).D_number)
{
strcpy(name,(S->
student[i]).S_name);
strcpy(number,(S->
student[i]).S_number);
t=(S->
student[i]).D_number;
strcpy((S->
(S->
student[j]).S_name,name);
student[j]).S_number,number);
student[j]).D_number=t;
}
//排序函数按照学号从小到大排序(冒泡法)
if(strcmp((S->
student[j]).S_number)>
0)
//查询函数以姓名为关键字进行查询(顺序查找)
inti,j=0;
charname[31];
请输入你要查找的学生的姓名(30个字符以内):
所查找学生信息如下:
if(strcmp(name,(S->
student[i]).S_name)==0)
j=1;
j)
\n查找失败,表中不存在该学生的信息!
//查询函数以学号为关键字进行查询(折半查找)
voidQuery_S_number(StS)
intflag,top,bottom,mid;
flag=0;
bottom=1;
top=S->
请输入你要查找学生的学号:
number);
Sort_S_number(S);
//将表中原数据按照学号从小到大排序
if(strcmp(number,(S->
student[1]).S_number)>
=0&
strcmp(number,(S->
Total]).S_number)<
=0)
while(bottom<
=top)
mid=(bottom+top)/2;
if(strcmp(number,(S->
student[mid]).S_number)==0)
student[mid]).S_name,(S->
student[mid]).S_number,(S->
student[mid]).D_number);
putchar('
flag=1;
break;
elseif(strcmp(number,(S->
student[mid]).S_number)>
bottom=mid+1;
else
top=mid-1;
//查询函数以寝室号为关键字进行查询(折半查找)
inti,j,m,n,base,top,mid;
j=0;
base=1;
请输入你要查询的寝室号:
i);
Sort_D_number(S);
//将表中原数据按照寝室号从小到大排序
所查找寝室信息如下:
if(i>
student[1]).D_number&
Total]).D_number)
while(base<
mid=(base+top)/2;
if(i==(S->
student[mid]).D_number)
m=mid;
n=mid-1;
while((S->
student[m]).D_number==i)
{
printf("
student[m]).S_name,(S->
student[m]).S_number,(S->
student[m]).D_number);
m++;
if(m>
Total)
break;
}
if(n>
while((S->
student[n]).D_number==i)
{
printf("
student[n]).S_name,(S->
student[n]).S_number,(S->
student[n]).D_number);
n--;
if(n<
1)
break;
}
j=1;
elseif(i>
base=mid+1;
\n查找失败,表中不存在该寝室的信息!
intj;
***********************************\n"
************按1按姓名查找***********\n"
************按2按学号查找***********\n"
************按3按寝室号查找**********\n"
do
请输入信息\n"
j);
switch(j)
case1:
Query_S_name(S);
break;
case2:
Query_S_number(S);
case3:
Query_D_number(S);
default:
选择错误:
请在选项之间选择!
while((j!
=1)&
(j!
=2)&
=3));
//存储函数
StudStd;
intflag1=0,flag2=0;
//判断存储是否成功
FILE*fp;
if((fp=fopen("
Dorm_Manage"
"
w"
))==NULL)
打开文件失败!
flag1=1;
exit(0);
//结束程序
if(fwrite(&
student[i],sizeof(Std),1,fp)!
=1)
数据写入错误\n\n"
flag2=1;
exit(0);
flag1&
!
flag2)
数据存储成功!
change=0;
fclose(fp);
//加载记录函数
r"
exit(0);
while(!
feof(fp))
fread(&
Total)],sizeof(Std),1,fp);
加载数据成功!
(S->
//由于读取问题,表中个数要减去
//退出程序时判断是否保存函数
if(i)Save(S);
}//菜单
//菜单
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~欢迎进入宿舍管理系统~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n"
*************************************菜单*************************************\n"
———————————————按a.添加学生信息—————————————————\n"
———————————————按b.修改学生信息—————————————————\n"
———————————————按c.删除学生信息—————————————————\n"
———————————————按d.查询学生信息—————————————————\n"
———————————————按e.显示所有学生信息———————————————\n"
———————————————按f.保存信息———————————————————\n"
———————————————按g.载入信息———————————————————\n"
———————————————按h保存退出————————————————————\n"
******************************************************************************\n"
chari;
StS;
S=(St)malloc(sizeof(Stu));
S->
Total=0;
Menu();
请选择所要实现的功能(请输入a~h中的任意一个数字):
//获取换行符
putchar('
switch(i)
case'
a'
:
Add(S);
b'
Alter(S);
c'
Delete(S);
d'
Search(S);
break;
e'
Display_All(S);
f'
Save(S);
g'
Load(S);
h'
Judge_Save(change,S);
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 实验 宿舍 管理 系统