洛阳理工学院数据结构课程设计报告.docx

上传人:b****6 文档编号:6864727 上传时间:2023-01-11 格式:DOCX 页数:25 大小:199.46KB
下载 相关 举报
洛阳理工学院数据结构课程设计报告.docx_第1页
第1页 / 共25页
洛阳理工学院数据结构课程设计报告.docx_第2页
第2页 / 共25页
洛阳理工学院数据结构课程设计报告.docx_第3页
第3页 / 共25页
洛阳理工学院数据结构课程设计报告.docx_第4页
第4页 / 共25页
洛阳理工学院数据结构课程设计报告.docx_第5页
第5页 / 共25页
点击查看更多>>
下载资源
资源描述

洛阳理工学院数据结构课程设计报告.docx

《洛阳理工学院数据结构课程设计报告.docx》由会员分享,可在线阅读,更多相关《洛阳理工学院数据结构课程设计报告.docx(25页珍藏版)》请在冰豆网上搜索。

洛阳理工学院数据结构课程设计报告.docx

洛阳理工学院数据结构课程设计报告

 

洛阳理工学院

 

课程设计报告

课程名称___________________________________

设计题目___________________________________

专业___________________________________

班级___________________________________

学号___________________________________

姓名___________________________________

完成日期___________________________________

课程设计任务书

设计题目:

员工管理系统

设计内容与要求:

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;i

if(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;i

printf("\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;i

if(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;i

if(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;i

if(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

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 总结汇报

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1