洛阳理工学院数据结构课程设计报告.docx
《洛阳理工学院数据结构课程设计报告.docx》由会员分享,可在线阅读,更多相关《洛阳理工学院数据结构课程设计报告.docx(25页珍藏版)》请在冰豆网上搜索。
洛阳理工学院数据结构课程设计报告
洛阳理工学院
课程设计报告
课程名称___________________________________
设计题目___________________________________
专业___________________________________
班级___________________________________
学号___________________________________
姓名___________________________________
完成日期___________________________________
课程设计任务书
设计题目:
员工管理系统
设计内容与要求:
1问题描述
每个员工的信息包括:
编号、姓名、性别、出生年月、学历、职务、电话、住址等。
系统能够完成员工信息的查询、更新、插入、删除等功能。
2基本要求
(1)录入:
输入员工信息,并用文件保存。
(2)查询:
按特定条件查找员工。
(3)更新:
按编号对某个员工的某项信息进行修改。
(4)插入:
加入新员工的信息。
(5)删除:
按编号删除已离职的员工的信息。
指导教师:
年月日
课程设计评语
成绩:
指导教师:
_______________
年月日
【算法思想】
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
#include
#include
#defineN100
structemployee
{
intnum;
charname[10];
charsex;
intage;
charxueli[30];
intwage;
charaddr[30];
longinttel;
}em[100];/*定义一个结构体*/
voidmenu();
voidinput();
voidsave(int);
voiddisplay();
voiddel();
voidadd();
voidsearch();
voidsearch_num();
voidsearch_xueli();
voidsearch_tel();
voidmodify();/*定义各函数*/
voidmenu()/*菜单函数*/
{
printf("\n");
printf("******************欢迎进入职工信息管理系统****************\n");
printf("1.录入职工信息");
printf("2.浏览职工信息\n");
printf("3.查询职工信息");
printf("4.删除职工信息\n");
printf("5.添加职工信息");
printf("6.修改职工信息\n");
printf("7.退出\n");
printf("**************************谢谢使用************************\n");
printf("\n");
printf("\n");
}
intmain()
{
menu();/*调用菜单函数*/
intn,flag;
chara;
do
{
printf("请选择你需要操作的步骤(1--7):
\n");
scanf("%d",&n);
if(n>=1&&n<=7)
{
flag=1;
break;
}
else
{
flag=0;
printf("您输入有误,请重新选择!
");
}
}
while(flag==0);
while(flag==1)
{
switch(n)
{
case1:
printf("◆◆◆输入职工信息◆◆◆\n");printf("\n");input();break;
case2:
printf("◆◆◆浏览职工信息◆◆◆\n");printf("\n");display();break;
case3:
printf("◆◆◆按职工号查询职工信息◆◆◆\n");printf("\n");search();break;
case4:
printf("◆◆◆删除职工信息◆◆◆\n");printf("\n");del();break;
case5:
printf("◆◆◆添加职工信息◆◆◆\n");printf("\n");add();break;
case6:
printf("◆◆◆修改职工信息◆◆◆\n");printf("\n");modify();break;
case7:
exit(0);break;
default:
break;
}
getchar();
printf("\n");
printf("是否继续进行(yorn):
\n");
scanf("%c",&a);
if(a=='y')
{
flag=1;
system("cls");/*清屏*/
menu();/*调用菜单函数*/
printf("请再次选择你需要操作的步骤(1--6):
\n");
scanf("%d",&n);
printf("\n");
}
else
exit(0);
}
}
voidinput()/*录入函数*/
{
inti,m;
printf("请输入需要创建信息的职工人数(1--100):
\n");
scanf("%d",&m);
for(i=0;i{
printf("请输入职工号:
");
scanf("%d",&em[i].num);
printf("\n");
printf("请输入姓名:
");
scanf("%s",em[i].name);
getchar();
printf("请输入性别(f--女m--男):
");
scanf("%c",&em[i].sex);
printf("请输入年龄:
");
scanf("%d",&em[i].age);
printf("请输入学历:
");
scanf("%s",em[i].xueli);
getchar();
printf("请输入工资:
");
scanf("%d",&em[i].wage);
printf("请输入住址:
");
scanf("%s",em[i].addr);
getchar();
printf("请输入电话:
");
scanf("%ld",&em[i].tel);
printf("\n");
}
printf("\n创建完毕!
\n");
save(m);
}
voidsave(intm)/*保存文件函数*/
{
inti;
FILE*fp;
if((fp=fopen("employee.txt","wb"))==NULL)/*创建文件并判断是否能打开*/
{
printf("cannotopenfile\n");
exit(0);
}
for(i=0;iif(fwrite(&em[i],sizeof(structemployee),1,fp)!
=1)
printf("filewriteerror\n");
fclose(fp);
}
intload()/*导入函数*/
{
FILE*fp;
inti=0;
if((fp=fopen("employee.txt","rb"))==NULL)
{
printf("cannotopenfile\n");
exit(0);
}
else
{
do
{
fread(&em[i],sizeof(structemployee),1,fp);
i++;
}
while(feof(fp)==0);
}
fclose(fp);
return(i-1);
}
voiddisplay()/*浏览函数*/
{
inti;
intm=load();
printf("\n职工号\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话\n");
for(i=0;iprintf("\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()/*删除函数*/
{
intm=load();
inti,j,n,t,flag;
charname[20];
printf("\n原来的职工信息:
\n");
display();/*调用浏览函数*/
printf("\n");
printf("请输入要删除的职工的姓名:
\n");
scanf("%s",name);
for(flag=1,i=0;flag&&i{
if(strcmp(em[i].name,name)==0)
{
printf("\n已找到此人,原始记录为:
\n");
printf("\n职工号\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话\n");
printf("\n%d\t%s\t%c\t%d\t%s\t%d\t%s\t%ld\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);
printf("\n确实要删除此人信息请按1,不删除请按0\n");
scanf("%d",&n);
if(n==1)/*如果删除,则其他的信息都往上移一行*/
{
for(j=i;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;
}
flag=0;
}
}
}
if(!
flag)
m=m-1;
else
printf("\n对不起,查无此人!
\n");
save(m);/*调用保存函数*/
printf("\n继续删除请按1,不再删除请按0\n");
scanf("%d",&t);
switch(t)
{
case1:
del();break;
case0:
break;
default:
break;
}
}
voidadd()/*添加函数*/
{
FILE*fp;
intn;
intcount=0;
inti;
intm=load();
printf("\n原来的职工信息:
\n");
display();/*调用浏览函数*/
printf("\n");
fp=fopen("employee.txt","a");
printf("请输入想增加的职工数:
\n");
scanf("%d",&n);
for(i=m;i<(m+n);i++)
{
printf("\n请输入新增加职工的信息:
\n");
printf("请输入职工号:
");
scanf("%d",&em[i].num);
printf("\n");
printf("请输入姓名:
");
scanf("%s",em[i].name);
getchar();
printf("请输入性别(f--女m--男):
");
scanf("%c",&em[i].sex);
printf("请输入年龄:
");
scanf("%d",&em[i].age);
printf("请输入学历:
");
scanf("%s",em[i].xueli);
printf("请输入工资:
");
scanf("%d",&em[i].wage);
printf("请输入住址:
");
scanf("%s",em[i].addr);
printf("请输入电话:
");
scanf("%d",&em[i].tel);
printf("\n");
count=count+1;
printf("已增加的人数:
\n");
printf("%d\n",count);
}
printf("\n添加完毕!
\n");
m=m+count;
printf("\n浏览增加后的所有职工信息:
\n");
printf("\n");
save(m);
display();
fclose(fp);
}
voidsearch()/*查询函数*/
{
intt,flag;
do
{
printf("\n按职工号查询请按1;按学历查询请按2;按电话号码查询请按3,进入主函数按4\n");
scanf("%d",&t);
if(t>=1&&t<=4)
{
flag=1;
break;
}
else
{
flag=0;
printf("您输入有误,请重新选择!
");
}
}
while(flag==0);
while(flag==1)
{
switch(t)
{
case1:
printf("按职工号查询\n");search_num();break;
case2:
printf("按学历查询\n");search_xueli();break;
case3:
printf("按电话号码查询\n");search_tel();break;
case4:
main();break;
default:
break;
}
}
}
voidsearch_num()
{
intnum;
inti,t;
intm=load();
printf("请输入要查找的职工号(0000001---9999999):
\n");
scanf("%d",&num);
for(i=0;iif(num==em[i].num)
{
printf("\n已找到此人,其记录为:
\n");
printf("\n职工号\t\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话\n");
printf("\n%d\t%s\t%c\t%d\t%s\t%d\t%s\t%ld\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);
break;
}
if(i==m)
printf("\n输入有误\n");
printf("\n");
printf("返回查询函数请按1,继续查询职工号请按2\n");
scanf("%d",&t);
switch(t)
{
case1:
search();break;
case2:
break;
default:
break;
}
}
voidsearch_xueli()
{
charxueli[30];
inti,t;
intm=load();
printf("请输入要查找的学历:
\n");
scanf("%s",xueli);
for(i=0;iif(strcmp(em[i].xueli,xueli)==0)
{
printf("\n已找到,其记录为:
\n");
printf("\n职工号\t\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话\n");
printf("\n%d\t%s\t%c\t%d\t%s\t%d\t%s\t%ld\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);
}
if(i==m)
printf("\n查询结束\n");
printf("\n");
printf("返回查询函数请按1,继续查询学历请按2\n");
scanf("%d",&t);
switch(t)
{
case1:
search();break;
case2:
break;
default:
break;
}
}
voidsearch_tel()
{
longinttel;
inti,t;
intm=load();
printf("请输入要查找的电话号码:
\n");
scanf("%ld",&tel);
for(i=0;iif(tel==em[i].tel)
{
printf("\n已找到此人,其记录为:
\n");
printf("\n职工号\t\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话\n");
printf("\n%d\t%s\t%c\t%d\t%s\t%d\t%s\t%ld\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);
break;
}
if(i==m)
printf("\n查询结束\n");
printf("\n");
printf("返回查询函数请按1,继续查询电话号码请按2\n");
scanf("%d",&t);
switch(t)
{
case1:
search();break;
case2:
break;
default:
break;
}
}
voidmodify()/*修改函数*/
{
intnum;
charname[10];
charsex;
intage;
charxueli[30];
intwage;
charaddr[30];
longinttel;
intb,c,i,n,t,flag;
intm=load();/*导入文件内的信息*/
printf("\n原来的职工信息:
\n");
display();/*调用浏览函数*/
printf("\n");
printf("请输入要修改的职工的姓名:
\n");
scanf("%s",name);
for(flag=1,i=0;flag&&i{
if(strcmp(em[i].name,name)==0)
{
printf("\n已找到此人,原始记录为:
\n");
printf("\n职工号\t\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话\n");
printf("\n%d\t%s\t%c\t%d\t%s\t%d\t%s\t%ld\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);
printf