简单的员工管理系统Word文件下载.docx
《简单的员工管理系统Word文件下载.docx》由会员分享,可在线阅读,更多相关《简单的员工管理系统Word文件下载.docx(14页珍藏版)》请在冰豆网上搜索。
typedefstructworker
{
intid;
charname[20];
charsex[3];
intage;
charedu[50];
intwages;
charadr[255];
charphone[13];
}WORKER,*PWORKER;
//typedefstructWORKER*PWORKER;
typedefstructlink
WORKERw;
structlink*next;
}LINK,*PLINK;
//typedefstructLINK*PLINK;
/*创建职工信息链表*/
PLINKcreate()
printf("
\t\t************录入职工信息请输入:
1************\n\n"
);
\t\t************浏览职工信息请输入:
2************\n\n"
\t\t************查询职工信息请输入:
3************\n\n"
\t\t************删除职工信息请输入:
4************\n\n"
\t\t************修改职工信息请输入:
5************\n\n"
\t\t************清屏请输入:
6************\n\n"
\t\t************退出请输入:
-1***********\n\n"
\t\t************************************************\n\n"
}
voidfind_sr(PLINKplink,char*str)
for(PLINKcurr=plink->
next;
curr!
=NULL;
curr=curr->
next)
{
if(strcmp(curr->
w.edu,str)==0)
{
printf("
职工工号:
%d\n"
curr->
w.id);
职工姓名:
%s\n"
w.name);
职工性别:
w.sex);
职工年龄:
w.age);
职工学历:
w.edu);
职工工资:
w.wages);
职工住址:
w.adr);
职工电话:
w.phone);
}
}
voidfindid(PLINKplink,intid)
next)
if(curr->
w.id==id)
voidshow(PLINKplink)
printf("
}
/*录入职工信息*/
intadd(PLINKp)
PLINKh=NULL;
PLINKq=(PLINK)malloc(sizeof(LINK));
if(NULL==q)
录入失败提示:
内存不足!
\n"
return-1;
printf("
请输入职工号(数字):
"
scanf("
%d"
&
q->
h=p->
while(h)
if(h->
w.id==q->
w.id)
free(q);
此职工号已经存在!
return-1;
}
h=h->
请输入职工姓名(文字):
%s"
请输入职工性别(文字):
请输入职工年龄(数字):
请输入职工学历(文字):
请输入职工工资(数字):
请输入职工住址(文字):
请输入职工电话(数字):
q->
next=p->
p->
next=q;
.^_^.录入成功!
.^_^.\n"
return-1;
/*按姓名查询*/
PLINKfindname(PLINKp,char*name)
message();
按姓名查询\n"
职工号\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话\n"
while(NULL!
=p->
if(0==strcmp(p->
next->
w.name,name))
%d\t%s\t%s\t%d\t%s\t%d\t%s\t%s\n"
p->
w.id,p->
w.name,p->
w.sex,p->
w.adr,
w.edu,p->
w.wages,p->
w.adr,p->
returnp;
p=p->
.^_^.查询结束!
returnNULL;
/*按职工号删除职工信息*/
intdel(PLINKp,intid)
按职工号删除职工信息\n"
if(p->
w.id==id)
PLINKq=p->
p->
.^_^.删除成功!
return1;
没有你输入的职工号!
/*程序结束释放内存*/
voidrelease(PLINKp)
PLINKq;
q=p;
free(q);
free(p);
/*查询调用*/
voidsearch()
{
charstr[20];
PLINKpworker;
intl;
\t\t\t\t*姓名查找按:
1*\n"
\t\t\t\t*学历查找按:
2*\n"
\t\t\t\t*职工号查按:
3*\n"
l);
if(l>
0&
&
l<
4)
{switch(l)
case1:
请输入要查询的职工姓名:
name);
findname(pworker,name);
break;
case2:
请输入要查询的职工学历:
"
str);
find_sr(pworker,str);
case3:
请输入要查询的职工号:
id);
findid(pworker,id);
\n\n选择完毕!
!
elseprintf("
\t\t\t\t输入有误!
/*修改职工信息*/
intmodify(PLINKp)
while(h)
break;
if(h==NULL)
找不到此职工,请重试\n"
h->
.^_^.修改成功!
intmain()
intcmd=0;
if(!
(pworker=create()))
exit(0);
while(cmd!
=-1)
switch(cmd)
{
case0:
case1:
add(pworker);
case2:
show(pworker);
case3:
search();
case4:
请输入要删除的职工号:
scanf("
del(pworker,id);
case5:
modify(pworker);
case6:
请输入操作命令数字:
scanf("
cmd);
\t\t>
>
谢谢使用<
<
\n\n"
release(pworker);
return0;
4.测试结果:
5.总结:
本次课程设计是围绕数据结构进行。
根据问题描述可知,需要解决问题并不复杂,整个问题只需要实现一个职工管理系统功能,那就是在这个系统中实现对职工信息的插入、删除、查询、排序、修改以及保存。
但是,为了实现该功能,却需要优秀的算法和数据结构以保证实现的时间和空间效率。
把职工信息存储在一个单链表中,利用指针实现对职工信息的各项基本操作。
虽然设计的程序完成了题目描述所需要实现的功能,但是仍然存在不如人意的地方。
那就是可以排序上面多设计几个算法。
实现多角度排序。
在这个系统中没有职工序号的信息,所以允许职工姓名相同,在很大程度上面,可能是的职工信息重复。
经过这次数据结构课程设计,我们不仅及时巩固的了数据结构、算法、以及软件工程的知识,并明白数据结构和算法对于程序时间和空间性能的影响,及软件工程提供的开发流程和工具对于实现特定功能程序的重要意义。
当我们面对一个实际问题,应该迅速根据问题性质和特点抽象成特定的数据结构,当然每个问题都有可能能够抽象成多种数据结构,每种数据结构适应于不同的算法。
因此应该综合考虑这样的数据结构、算法以及它们的空间和时间效率,然后从中选择一个作为实现程序的基础。
此外,对程序的测试应该要仔细,根据模块的特点和测试阶段,采用各种软件测试方法对程序进行测试,确保各个模块的正确性和完整性,最后集成起来测试其是否正确和完整地实现了问题描述中要求的功能。