收藏 分销(赏)

C++人事管理系统课程设计报告.doc

上传人:二*** 文档编号:4513820 上传时间:2024-09-26 格式:DOC 页数:32 大小:185KB
下载 相关 举报
C++人事管理系统课程设计报告.doc_第1页
第1页 / 共32页
亲,该文档总共32页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

1、. .一、 设计题目问题描述和要求1 题目:人事管理系统 2 问题描述:某小型公司,主要有四类人员:经理、兼职技术人员、销售经理和兼职推销员。现在,需要存储这些人员的XX、编号、级别、当月薪水,计算月薪总额并显示全部信息。 要求: (1) 其中,人员编号在生成人员信息时同时生成,每输入一个人员信息编号顺序加1。 (2) 程序对所有人员有提升级别的功能 (3) 月薪的计算方法是:经理拿固定月薪,兼职技术人员按工作小时数领取月薪,兼职推销员的报酬按该推销员当月销售额提成 ,销售经理既拿固定月薪也领取销售提成。 (4) 能按XX或者编号显示、查找、增加、删除和保存各类人员的信息 二、 系统分析与模块

2、设计根据问题描述和要求,系统要求能够按XX或者编号显示、查找、增加、删除和保存各类人员的信息。确定程序至少应该具备如下功能:“查询人员、“增加人员、“删除人员、“数据存盘根本模块。系统既然具有“数据存盘功能人员数据可以保存到磁盘文件,那么也就意味着今后可以从磁盘文件读出人员数据,所以系统增加了“人员数据装入模块,以方便用户使用、防止数据重复录入。考虑到系统实现简捷,人员数据文件采用文本文件,人员数据文件名:Person.txt。做为一个完整系统,除了具有增加人员,删除人员信息模块,还应该具有修改人员相关信息的功能,所以本系统设计时考虑增加“修改人员模块。考虑到根据编号查找人员信息功能在“删除人

3、员、“修改人员等模块都使用,所以可以考虑设置为一个模块。考虑到系统要求人员编号在生成人员信息时同时生成,每输入一个人员信息编号顺序加1。这样就要求人员编号在增加人员时自动生成(增加1)且不重复。根据这个要求,可以考虑设置一个全局量:“当前最大编号,每增加一个人员,当前最大编号自动增1,然后新增加人员使用这个编号。为了保证系统能记忆这个编号,可以使用一个数据文件保存当前这个编号。系统每次开场运行前从文件读入这个编号,随着人员增加,编号自动增加,系统每次运行完毕时将这个编号写入文件。本系统将初值(没有一个用户时)设置为0。考虑到人员的许多固定信息如:经理、销售经理的固定月薪,销售经理、销售人员提成

4、,技术人员小时工资等都是一些不需要每个人员都要输入的信息,所以可以将这些信息都保存在一个数据文件中,本系统为了方便起见,将这些信息与“最大编号全部保存在一个文件中,并使用“根底数据设置模块进展设置和管理。根底数据文件也采用文本文件,根底数据文件名:Base.txt。本系统还提供“查询本月经营信息帮助计算销售总额,工资总额,并按照公式计算本月盈亏。综合考虑系统具有下面8项功能模块:增加人员,删除人员,修改人员,查询本月经营信息,根底数据设置,数据存盘,数据装入。系统使用的数据文件格式如下:Base.txt:(格式:工程 数据)经理固定月薪3000销售经理固定月薪1000销售经理提成1销售人员提成

5、2技术人员小时工资20ID6Person.txt:格式:编号,XX,人员类别,其它数据,销售员销售额,技术人员工作小时2wang31000003liu14wu41005huang26tao3150000注:人员类型编号1经理;2销售经理;3销售员;4技术人员三、 系统设计1. 系统总体框架使用面向对象的程序设计思想进展分析,整个系统涉及两大类信息和操作,公司,人员。所以系统主要涉及两个大类:公司类pany、人员类Person。系统的总体框架就是公司类,人员类的定义;主函数中定义一个公司对象,循环显示主菜单并根据用户选择调用公司类的相应方法(成员函数)。(1)公司类pany:考虑系统操作的人员信

6、息的数量具有不确定性,所以考虑使用链表保存、处理人员信息。公司类包含:所有人员信息的一个不带头结点的链表作为数据成员及可以对人员信息进展增,删,改,查询经营信息,根底数据设置,数据存盘,数据装入等操作的相关模块(Add,Delete,Modify,Query,Set,Save,Load)作为成员函数。(2)人员类Person:所有人员都具有的公共信息及操作可以使用人员类进展描述。由于系统具有4类人员且4类人员数据,操作有所不同,如销售员包含销售额,而技术人员包含工作小时数且计算工资的方法不同,所以应当为4类人员创立相应的Person类的派生类。(3)为了使公司类可以方便处理人员信息,可以考虑将

7、公司类确定为人员类的友元类或者人员类提供公共的方法以便公司类进展操作。为了公司类可以用共同方法操作人员类,可以将人员类的方法确定为虚函数。2. 类的层次图Person No,Name,Duty,Earning,next,Person(),CalcSalary(),Output()Manager SalesSalesManager Technician Manager(), Amount, Amount, t,CalcSalary(), Sales(),GetAmount(), SalesManager(),Technician(),Output() SetAmount(), SetAmount

8、(),GetT(),SetT(),CalcSalary(), CalcSalary(),CalcSalary(),Output() Output() Output()其中:1Person类的No-人员编号,Name-人员XX,Duty-人员类别,Earning-工资,next-指向下一个人员的指针;Person类的CalcSalary(),Output()定义为纯虚函数分别表示要计算人员工资和输出人员信息,由于定义纯虚函数,所以Person是抽象类,具体计算工资,输出人员信息由派生类完成。2各个派生的类,包含本类对象特有的数据,Sales:Amount-销售员销售额,SalesManager:

9、Amount-销售经理的总销售额系统统计各个销售员销售额得到销售经理的总销售额,Technician:t-技术人员工作小时数。pany Person *Worker,Clear(),pany(),pany(),Add(),Delete(),Modify(),Query(),Set(),Save(),Load()其中:1Worker就是人员链表。2Clear()用于去除人员链表所有结点。3Add(),Delete(),Modify(),Query(),Set(),Save(),Load()分别表示系统各个功能模块:增加人员,删除人员,修改人员,查询本月经营信息,根底数据设置,数据存盘,数据装入。

10、3. 系统关键算法流程图(1)主函数流程(2) pany:Add()(3) pany:Delete()(4) pany:Modify(5) pany:Query() (6)pany:Save()(7) pany:Load()四、 源程序清单参见附录五、 系统测试列出各功能具体的输入数据及对应的输出结果,说明其是否符合设计要求六、 小结(设计过程心得体会)附录:/*本程序有关的两个数据文件:base.txt根底数据文件(必须存在,且按规定格式保存)person.txt人员信息文件(可选)*/#include #include #include #include /全局数据,对象double Ma

11、nagerSalary; /经理固定月薪double SalesManagerSalary; /销售经理固定月薪double SalesManagerPercent; /销售经理提成double SalesPercent; /销售人员提成double WagePerHour; /技术人员小时工资int ID; /员工标识(要保证唯一)class Person /员工类protected: int No; /编号 char Name20; /XX int Duty; /岗位 double Earning; /收入 Person *next;public: Person(char ID,char

12、*Name,int Duty) this-Duty=Duty; strcpy(this-Name,Name); this-No=ID; virtual void CalcSalary()=0; virtual void Output()=0; friend class pany;class Manager:public Person /经理类public: Manager(char ID,char *Name,int Duty):Person(ID,Name,Duty) void CalcSalary()Earning=ManagerSalary; void Output() CalcSala

13、ry(); coutNotNamet经理tEarningendl; ;class SalesManager:public Person /销售经理类private: double Amount;public: SalesManager(char ID,char *Name,int Duty):Person(ID,Name,Duty) void SetAmount(double s) Amount=s; void CalcSalary() Earning=SalesManagerSalary+Amount*SalesManagerPercent/100; void Output() CalcSa

14、lary(); coutNotNamet销售经理tEarningt=T; double GetT() return t; void SetT(double T) this-t=T; void CalcSalary() Earning=WagePerHour*t; void Output() CalcSalary(); coutNotNamet技术员tttEarningAmount=Amount; double GetAmount() return Amount; void SetAmount(double Amount) this-Amount=Amount; void CalcSalary(

15、) Earning=SalesPercent/100*Amount; void Output() CalcSalary(); coutNotNamet销售员tAmounttEarningnext; delete Worker; Worker=p; Worker=0; void Add(); /增加人员 void Delete(); /删除人员 void Modify(); /修改人员 void Query(); /查询人员 void Set(); /根底数据设置 void Save(); /数据存盘(包括根底数据,人员数据) void Load(); /数据装入(包括根底数据,人员数据);vo

16、id pany:Clear() /去除存中人员数据(部使用) Person* p=Worker; while(p) Worker=p-next; delete p; p=Worker; void pany:Add() Person *p; /新结点指针 int Duty; char Name20; double Amount,T; coutn* 新增员工 *n; /输入员工信息 ID+; coutDuty; coutName; if(Duty=3) coutAmount; else if(Duty=4) coutT; /创立新员工结点 switch(Duty) case 1:p=new Man

17、ager(ID,Name,Duty); break; case 2:p=new SalesManager(ID,Name,Duty); break; case 3:p=new Sales(ID,Name,Duty,Amount); break; case 4:p=new Technician(ID,Name,Duty,T); break; p-next=0; /员工结点参加链表 if(Worker) /假设已经存在结点 Person *p2; p2=Worker; while(p2-next) /查找尾结点 p2=p2-next; p2-next=p; /连接 else /假设不存在结点(表空

18、) Worker=p; /连接 void pany:Delete() /删除人员 int No; coutn* 删除员工 *n; coutNo; /查找要删除的结点 Person *p1,*p2; p1=Worker; while(p1) if(p1-No=No) break; else p2=p1; p1=p1-next; /删除结点 if(p1!=NULL)/假设找到结点,那么删除 if(p1=Worker) /假设要删除的结点是第一个结点 Worker=p1-next; delete p1; else /假设要删除的结点是后续结点 p2-next=p1-next; delete p1;

19、cout找到并删除n; else /未找到结点 cout未找到!n;void pany:Modify() int No,Duty; char Name20; double Amount,T; coutn* 修改员工 *n; coutNo; /查找要修改的结点 Person *p1,*p2; p1=Worker; while(p1) if(p1-No=No) break; else p2=p1; p1=p1-next; /修改结点 if(p1!=NULL)/假设找到结点 p1-Output(); coutDuty; if(p1-Duty!=Duty) /假设岗位发生变动 /修改其它数据 cout

20、Name; if(Duty=3) coutAmount; else if(Duty=4) coutT; /创立新员工结点 Person *p3; switch(Duty) case 1:p3=new Manager(p1-No,Name,Duty); break; case 2:p3=new SalesManager(p1-No,Name,Duty); break; case 3:p3=new Sales(p1-No,Name,Duty,Amount); break; case 4:p3=new Technician(p1-No,Name,Duty,T); break; /员工结点替换到链表

21、p3-next=p1-next; if(p1=Worker) /假设要替换的结点是第一个结点 Worker=p3; else /假设要删除的结点是后续结点 p2-next=p3; /删除原来的员工结点 delete p1; else /假设岗位没有变动 coutp1-Name; if(Duty=3) coutAmount; (Sales *)p1)-SetAmount(Amount); else if(Duty=4) coutT; (Technician *)p1)-SetT(T); cout修改成功!n; else /未找到结点 cout未找到!n;void pany:Query() cou

22、tDuty=3)sum+=(Sales *)p)-GetAmount(); p=p-next; p=Worker; double sum2=0; /工资总和 while(p) if(p-Duty=2)(SalesManager *)p)-SetAmount(sum); p-Output(); sum2+=p-Earning; p=p-next; cout本月盈利:sum*0.20-sum2endl; cout(按照20利润计算)n;void pany:Set() coutn* 设置根底数据 *n; cout经理固定月薪ManagerSalaryManagerSalary; cout销售经理固定

23、月薪SalesManagerSalarySalesManagerSalary; cout销售经理提成SalesManagerPercentSalesManagerPercent; cout销售人员提成SalesPercentSalesPercent; cout技术人员小时工资WagePerHourWagePerHour; cout=IDID;void pany:Save() /数据存盘(包括根底数据,人员数据),均采用文本文件 ofstream fPerson,fBase; char c; coutc; if(toupper(c)!=Y)return; /保存人员编号、XX、岗位 fPerso

24、n.open(person.txt,ios:out); Person *p=Worker; while(p) fPersonNotNametDutyDuty=3) fPersonGetAmount()Duty=4) fPersonGetT()t; fPersonnext; fPerson.close(); /保存根底数据 fBase.open(base.txt,ios:out); fBase经理固定月薪tManagerSalaryendl; fBase销售经理固定月薪tSalesManagerSalaryendl; fBase销售经理提成tSalesManagerPercentendl; fB

25、ase销售人员提成tSalesPercentendl; fBase技术人员小时工资tWagePerHourendl; fBaseIDtIDendl; fPerson.close(); coutbufManagerSalary; /经理固定月薪 fBasebufSalesManagerSalary; /销售经理固定月薪 fBasebufSalesManagerPercent; /销售经理提成 fBasebufSalesPercent; /销售人员提成 fBasebufWagePerHour; /技术人员小时工资 fBasebufID; /员工标识 fBase.close(); /去除存人员数据

26、Clear(); /人员数据数据装入 ifstream fPerson; Person *p=Worker; int No; char Name20; int Duty; double Amount,T; fPerson.open(person.txt,ios:in); /读一条记录 fPersonNoNameDuty; if(Duty=3)fPersonAmount; else if(Duty=4)fPersonT; while(fPerson.good() /创立员工结点 switch(Duty) case 1:p=new Manager(No,Name,Duty); break; cas

27、e 2:p=new SalesManager(No,Name,Duty); break; case 3:p=new Sales(No,Name,Duty,Amount); break; case 4:p=new Technician(No,Name,Duty,T); break; p-next=0; /员工结点参加链表 if(Worker) /假设已经存在结点 Person *p2; p2=Worker; while(p2-next) /查找尾结点 p2=p2-next; p2-next=p; /连接 else /假设不存在结点(表空) Worker=p; /连接 /读下一条记录 fPerso

28、nNoNameDuty; if(Duty=3)fPersonAmount; else if(Duty=4)fPersonT; fPerson.close(); coutn人员和根底数据已经装入.n;void main() char c; pany a; do coutn* 公司人员管理系统 *n; cout1增加人员n; cout2删除人员n; cout3修改人员n; cout4查询本月经营信息n; cout5根底数据设置n; cout6数据存盘n; cout7数据装入n; coutc; switch(c) case 1: a.Add(); break; case 2: a.Delete();break; case 3: a.Modify();break; case 4: a.Query(); break; case 5: a.Set(); break; case 6: a.Save(); break; case 7: a.Load(); break; while(c!=8);. .word.zl.

展开阅读全文
相似文档                                   自信AI助手自信AI助手
猜你喜欢                                   自信AI导航自信AI导航
搜索标签

当前位置:首页 > 学术论文 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服