洛阳理工学院数据结构课程设计报告Word格式.docx
- 文档编号:19886229
- 上传时间:2023-01-11
- 格式:DOCX
- 页数:25
- 大小:199.46KB
洛阳理工学院数据结构课程设计报告Word格式.docx
《洛阳理工学院数据结构课程设计报告Word格式.docx》由会员分享,可在线阅读,更多相关《洛阳理工学院数据结构课程设计报告Word格式.docx(25页珍藏版)》请在冰豆网上搜索。
1、首先进行需求分析,搞清楚系统功能和任务;
2、然后在总体设计中确定模块结构、划分功能模块,将软件功能需求分配给所划分的最单元模块。
确定模块间的联系,确定数据结构、文件结构、数据库模式,确定测试方法与策略;
3、在详细设计中,为每个模块确定采用的算法,选择适当的工具表达算法的过程来描述模块的详细过程。
确定每一模块采用的数据结构和模块接口的细节,以及文件操作函数的作用,读取和保存关闭文件等。
【函数模块划分】
(1)菜单函数:
voidmenu()
(2)输入函数:
voidinput()
(3)保存函数:
voidsave(int)
(4)浏览函数:
voiddisplay()
(5)删除函数:
voiddel()
(6)增加函数:
voidadd()
(7)查询函数:
voidsearch()
(8)通过工号查询函数:
voidsearch_num()
(9)通过学历查询函数:
voidsearch_xueli()
(10)通过电话查询函数voidsearch_tel()
(11)修改函数:
voidmodify()
(12)主函数:
intmain()
其结构流程如下
主函数:
voidmain()
各模块间的层次图:
【详细设计】
1、主菜单模块:
显示员工管理系统的主菜单,供用户选择所需的功能,通过自己定义的intmain()函数来实现。
2、添加员工模块:
输入员工的编号、姓名、年龄、职位、工龄以,通过自己定义的voidadd()函数来实现。
3、查询员工信息模块:
浏览所有员工的相关信息,通过自己定义的voidsearch()函数来实现。
(1)按员工学历查询:
可以按员工学历来查询员工的相关信息,通过自己定义的voidsearch-xueli()函数来实现。
(2)按员工编号查询:
可以按员工编号来查询员工的相关信息,通过自己定义的voidsearch-num()函数来实现。
(3)按员工电话查询:
可以按员工电话来查询员工的相关信息,通过自己定义的voidsearch-tel()函数来实现。
4、删除员工模块:
删除需要删除的员工的所有信息,通过自己定义的voiddel()函数来实现。
5、修改模块:
可以修改需要修改的员工的相关信息,通过自己定义的voidmodify()函数来实现。
6、退出系统模块:
退出员工信息管理系统,通exit(0)函数来实现。
【数据结构】
对员工信息进行结构体定义
structemployee
{
intnum;
charname[10];
charsex;
intage;
charxueli[30];
intwage;
charaddr[30];
longinttel;
}em[100];
【测试结果】
(1)输入三个员工的信息,并保存。
图一:
输入三个员工信息
(2)退出系统后,再进入系统,浏览信息,看是否保存成功。
图二:
浏览信息
(3)按员工号查询员工信息,输入错误员工号,看是否能提示输入有误。
图三:
按职工号查找员工
图四:
输入错误职工号结果
(4)删除一个员工的信息,看能否保存到文件中。
删除员工信息后,退出系统,再打开系统,浏览员工信息。
图五:
删除员工信息
图六:
信息浏览
退出系统后,重新浏览,结果如上图,信息保存成功。
(5)添加一个职工信息,浏览添加后的信息,看信息能否保存。
图七:
添加员工信息
(6)修改一个员工的信息,浏览修改后的信息,看能否保存成功。
图八:
修改员工信息
【源代码】
#include<
stdio.h>
stdlib.h>
string.h>
#defineN100
/*定义一个结构体*/
voidmenu();
voidinput();
voidsave(int);
voiddisplay();
voiddel();
voidadd();
voidsearch();
voidsearch_num();
voidsearch_xueli();
voidsearch_tel();
voidmodify();
/*定义各函数*/
voidmenu()/*菜单函数*/
printf("
\n"
);
******************欢迎进入职工信息管理系统****************\n"
1.录入职工信息"
2.浏览职工信息\n"
3.查询职工信息"
4.删除职工信息\n"
5.添加职工信息"
6.修改职工信息\n"
7.退出\n"
**************************谢谢使用************************\n"
}
intmain()
{
menu();
/*调用菜单函数*/
intn,flag;
chara;
do
请选择你需要操作的步骤(1--7):
scanf("
%d"
&
n);
if(n>
=1&
&
n<
=7)
flag=1;
break;
else
flag=0;
您输入有误,请重新选择!
"
while(flag==0);
while(flag==1)
switch(n)
case1:
◆◆◆输入职工信息◆◆◆\n"
input();
case2:
◆◆◆浏览职工信息◆◆◆\n"
display();
case3:
◆◆◆按职工号查询职工信息◆◆◆\n"
search();
case4:
◆◆◆删除职工信息◆◆◆\n"
del();
case5:
◆◆◆添加职工信息◆◆◆\n"
add();
case6:
◆◆◆修改职工信息◆◆◆\n"
modify();
case7:
exit(0);
default:
getchar();
是否继续进行(yorn):
%c"
a);
if(a=='
y'
)
system("
cls"
/*清屏*/
请再次选择你需要操作的步骤(1--6):
else
voidinput()/*录入函数*/
inti,m;
请输入需要创建信息的职工人数(1--100):
m);
for(i=0;
i<
m;
i++)
请输入职工号:
"
em[i].num);
请输入姓名:
%s"
em[i].name);
请输入性别(f--女m--男):
em[i].sex);
请输入年龄:
em[i].age);
请输入学历:
em[i].xueli);
请输入工资:
em[i].wage);
请输入住址:
em[i].addr);
请输入电话:
%ld"
em[i].tel);
\n创建完毕!
save(m);
voidsave(intm)/*保存文件函数*/
inti;
FILE*fp;
if((fp=fopen("
employee.txt"
"
wb"
))==NULL)/*创建文件并判断是否能打开*/
printf("
cannotopenfile\n"
i++)/*将内存中职工的信息输出到磁盘文件中去*/
if(fwrite(&
em[i],sizeof(structemployee),1,fp)!
=1)
filewriteerror\n"
fclose(fp);
intload()/*导入函数*/
inti=0;
if((fp=fopen("
rb"
))==NULL)
do
fread(&
em[i],sizeof(structemployee),1,fp);
i++;
while(feof(fp)==0);
return(i-1);
voiddisplay()/*浏览函数*/
intm=load();
\n职工号\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话\n"
for(i=0;
i++)/*m为输入部分的职工人数*/
\n%d\t%s\t%c\t%d\t%s\t%d\t%s\t%d\n"
em[i].num,em[i].name,em[i].sex,em[i].age,em[i].xueli,em[i].wage,em[i].addr,em[i].tel);
voiddel()/*删除函数*/
inti,j,n,t,flag;
charname[20];
\n原来的职工信息:
/*调用浏览函数*/
请输入要删除的职工的姓名:
name);
for(flag=1,i=0;
flag&
if(strcmp(em[i].name,name)==0)
\n已找到此人,原始记录为:
printf("
\n%d\t%s\t%c\t%d\t%s\t%d\t%s\t%ld\n"
\n确实要删除此人信息请按1,不删除请按0\n"
if(n==1)/*如果删除,则其他的信息都往上移一行*/
for(j=i;
j<
m-1;
j++)
strcpy(em[j].name,em[j+1].name);
em[j].num=em[j+1].num;
em[j].sex=em[j+1].sex;
em[j].age=em[j+1].age;
strcpy(em[j].xueli,em[j+1].xueli);
em[j].wage=em[j+1].wage;
strcpy(em[j].addr,em[j+1].addr);
em[j].tel=em[j+1].tel;
if(!
flag)
m=m-1;
\n对不起,查无此人!
/*调用保存函数*/
\n继续删除请按1,不再删除请按0\n"
t);
switch(t)
case0:
voidadd()/*添加函数*/
intn;
intcount=0;
inti;
intm=load();
display();
fp=fopen("
a"
请输入想增加的职工数:
for(i=m;
(m+n);
\n请输入新增加职工的信息:
请输入职工号:
count=count+1;
已增加的人数:
%d\n"
count);
\n添加完毕!
m=m+count;
\n浏览增加后的所有职工信息:
voidsearch()/*查询函数*/
intt,flag;
\n按职工号查询请按1;
按学历查询请按2;
按电话号码查询请按3,进入主函数按4\n"
if(t>
t<
=4)
按职工号查询\n"
search_num();
按学历查询\n"
search_xueli();
按电话号码查询\n"
search_tel();
main();
default:
inti,t;
请输入要查找的职工号(0000001---9999999):
num);
if(num==em[i].num)
\n已找到此人,其记录为:
\n职工号\t\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话\n"
if(i==m)
\n输入有误\n"
返回查询函数请按1,继续查询职工号请按2\n"
break;
请输入要查找的学历:
xueli);
if(strcmp(em[i].xueli,xueli)==0)
\n已找到,其记录为:
\n查询结束\n"
返回查询函数请按1,继续查询学历请按2\n"
voidsearch_tel()
inti,t;
请输入要查找的电话号码:
tel);
if(tel==em[i].tel)
返回查询函数请按1,继续查询电话号码请按2\n"
voidmodify()/*修改函数*/
intnum;
longinttel;
intb,c,i,n,t,flag;
/*导入文件内的信息*/
请输入要修改的职工的姓名:
printf
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 洛阳 理工学院 数据结构 课程设计 报告
![提示](https://static.bdocx.com/images/bang_tan.gif)