C语言课程设计学生宿舍管理系统Word格式.docx
《C语言课程设计学生宿舍管理系统Word格式.docx》由会员分享,可在线阅读,更多相关《C语言课程设计学生宿舍管理系统Word格式.docx(19页珍藏版)》请在冰豆网上搜索。
2、数据存储
信息的录入要求用链表,把输入的信息要求存储到指定文件夹中,以便随时查看,也可供程序调用,方便操作人员不用重复输入数据。
3、数据的更新
更新包括插入、删除、修改。
删除分根据学号删除和根据学生的楼层信息删除。
5、数据的查询
查询可以根据学号和宿舍信息不同方面进行查询,方便操作者使用。
6、数据的排序
操作者可以使所输入的信息按学号排序。
7、数据的统计
按整体统计,统计所有学生人数,男生人数和女生人数。
四、概要设计
1.系统结构图(功能模块图)
主函数
录入存储
数据操作
输出信息
输入
统计
查找
修改
删除
插入
显示
排序
2.功能模块说明:
(1).数据录入:
创建单链表,调用Initnode()函数申请头结点,在调用append(),在调用Write_to_File()函数将信息写入文件中,
(2)插入模块:
先将文件信息读出,再调用insert()函数,可以向文件中插入信息。
(3)插入模块:
先将文件信息读出,再调用del()函数,可以将输入错误或者
需要的信息删除。
(4)修改模块:
先将文件信息读出,再调用modify()函数,将输入错误的信息修改。
(5)查询模块:
先将文件信息读出,再调用search(),在search()中有调用两个
数,一个按照宿舍信息查询sushe_search(),需要楼号和宿舍号,一个按照生信息查询xuehao_search()需要学生学号或者姓名。
(6)排序模块:
先将文件信息读出,再调用sort(),按照学生学号排序,拍完续没有直接写入文件,如果要直接写入调用文件读入函数Write_to_File().
(7)统计模块:
先将文件信息读出,再调用tongji()函数,统计了女生人数和男生人数,还统计了总人数.
五.详细过程和运行结果:
开始
输入要删除学生的学号num
p->
num:
num
删除该学生信息
结束
组织循环,扫描存储学生信息的链表
删除模块
!
=
==
插入模块
查找模块
选择查找方式
按学生学号查找
输入要查找的学生学号num
输出该学生的信息
按宿舍信息查找
输入要查找的学生lounum,sushenum,chuangnum
lounum:
sushenu
sushenum:
chuangnum:
chuangnum
输出该学生信息
结束
组织循环,扫描存储学生信息的链表表
=
修改模块
排序模块
统计模块
六.参考文献:
《C语言程序设计》:
王曙燕
七.源代码
#include<
>
根据学生学号删除\n"
);
printf("
\n2.根据宿舍信息删除\n"
\n请选择删除方式:
"
scanf("
%c"
&
ch);
while
(1)
{
if(ch=='
1'
)
{
printf("
\n请输入学生学号:
scanf("
%d"
&
N);
while(p)
{
if(p->
num==N)
{
q->
next=p->
next;
printf("
删除成功!
break;
}
q=p;
p=p->
}
if(p==NULL)
printf("
\n未找到此学生"
break;
}else
{
free(p);
}
}
elseif(ch=='
2'
\n请输入宿舍信息(楼号宿舍床号):
%d%d%d"
lounum,&
sushenum,&
chuangnum);
while(p!
=NULL)
lounum==lounum&
&
p->
sushenum==sushenum&
chuangnum)
{
未找到此学生"
break;
}
\n\n是否继续:
Y/N"
h);
}while(h=='
Y'
||h=='
y'
Write_to_File(head);
}
voidinsert()/*用头插法插入学生信息*/
{
Stu*p,*head;
charch;
InitStu(&
head);
Read_from_File(head);
system("
clear"
do
{
p=(Stu*)malloc(sizeof(Stu));
next=NULL;
printf("
\t\t请输入插入的学生信息:
\n"
\t学号:
scanf("
num);
\n\t姓名:
%s"
p->
name);
\n\t性别:
sex);
\n\t专业:
zhuanye);
\n\t楼号:
lounum);
\n\t宿舍号:
sushenum);
\n\t床号:
next=head->
head->
next=p;
\n\n是否继续插入Y/N"
}while(ch=='
||ch=='
voidmodify()/*修改学生信息(按学号修改)*/
Stu*head;
Stu*p;
intN;
\n\n请输入修改的学生学号:
"
p=head->
{
while(p!
if(p->
system("
\n请输入新的学生信息:
\n学号:
\n姓名:
\n性别:
scanf("
\n专业:
\n楼号:
\n宿舍号:
\n床号:
break;
p=p->
if(p==NULL)
printf("
else
修改成功\n"
\n\n继续修改Y/N"
voidxuehao_search(Stu*head)/*按照学生学号查找*/
intnum;
next;
system("
\n请输入要查找的学生学号:
while(p!
if(p->
num==num)
学号姓名性别专业楼号宿舍号床号\n\n"
%-8d%-8s%-4c%-8s%-8d%-8d%-5d\n"
num,p->
name,p->
sex,p->
zhuanye,
p->
lounum,p->
sushenum,p->
if(p==NULL)
\n\n继续查找Y/N"
||ch=='
voidsushe_search(Stu*head)/*按照宿舍信息查找*/
intlounum,sushenum,chuangnum;
\n请输入要查找的学生宿舍信息(楼号宿舍床号):
\n楼号:
\n宿舍号:
\n床号:
sushenum==sushenum
&
chuangnum==chuangnum)
{
sex,
p->
\n\n是否继续Y/N"
voidSearch()/*查找学生信息*/
{
intchoose;
\n1.根据宿舍信息查找."
\n2.根据学生学号查找."
\n3.退出.\n\n"
\n请选择查找方式:
choose);
switch(choose)
case1:
sushe_search(head);
break;
case2:
xuehao_search(head);
break;
case3:
}
voidsort()/*将学生信息按学号排序*/
Stu*i,*j,*k;
Stu*m,*n;
Stu*temp;
intl=0;
入学生信息\n\n"
2.删除学生信息\n\n"
3.插入学生信息\n\n"
4.修改学生信息\n\n"
5.显示学生信息\n\n"
6.查找学生信息\n\n"
7.排序学生信息\n\n"
8.统计学生信息\n\n"
0.退出系统\n"
==========================================\n"
请选择0-8:
\n"
\n请选择要进行的操作:
choice);
switch(choice)
append();
del();
insert();
case4:
modify();
case5:
display();
case6:
Search();
case7:
sort();
case8:
tongji();
case0:
\n\t\t确定退出(Y/N)"
if(ch=='
exit(0);
N'
n'