还剩17页未读,继续阅读
本资源只提供10页预览,全部文档请下载后查看!喜欢就下载吧,查找使用更方便
文本内容:
1、设计题目(问题)描述和要求1.题目人事管理系统2.问题描述某小型公司,主要有四类人员经理、__技术人员、销售经理和__推销员现在,需要存储这些人员的姓名、编号、级别、当月薪水,计算月薪总额并显示全部信息要求
(1)其中,人员编号在生__员信息时同时生成,每输入一个人员信息编号顺序加1
(2)程序对所有人员有提升级别的功能
(3)月薪的计算方法是经理拿固定月薪,__技术人员按工作小时数__月薪,__推销员的报酬按该推销员当月销售额提成销售经理既拿固定月薪也__销售提成
(4)能按姓名或者编号显示、查找、增加、删除和保存各类人员的信息
2、系统分析与模块设计根据问题描述和要求,系统要求能够按姓名或者编号显示、查找、增加、删除和保存各类人员的信息确定程序至少应该具备如下功能“查询人员”、“增加人员”、“删除人员”、“数据存盘”基本模块系统既然具有“数据存盘”功能-人员数据可以保存到磁盘文件,那么也就意味着今后可以从磁盘文件读出人员数据,所以系统增加了“人员数据装入”模块,以方便用户使用、避免数据重复录入考虑到系统实现简捷,人员数据文件采用文本文件,人员数据文件名Person.___做为一个完整系统,除了具有增加人员,删除人员信息模块,还应该具有修改人员相关信息的功能,所以本系统设计时考虑增加“修改人员”模块考虑到根据编号查找人员信息功能在“删除人员”、“修改人员”等模块都使用,所以可以考虑设置为一个模块考虑到系统要求人员编号在生__员信息时同时生成,每输入一个人员信息编号顺序加1这样就要求人员编号在增加人员时自动生成增加1且不重复根据这个要求,可以考虑设置一个全局量“当前最大编号”,每增加一个人员,当前最大编号自动增1,然后新增加人员使用这个编号为了保证系统能记忆这个编号,可以使用一个数据文件保存当前这个编号系统每次开始运行前从文件读入这个编号,随着人员增加,编号自动增加,系统每次运行结束时将这个编号写入文件本系统将初值没有一个用户时设置为0考虑到人员的许多固定信息如经理、销售经理的固定月薪,销售经理、销售人员提成,技术人员小时工资等都是一些不需要每个人员都要输入的信息,所以可以将这些信息都保存在一个数据文件中,本系统为了方便起见,将这些信息与“最大编号”全部保存在一个文件中,并使用“基础数据设置”模块进行设置和管理基础数据文件也采用文本文件,基础数据文件名Base.___本系统还提供“查询本月经营信息”帮助计算销售总额,工资总额,并按照公式计算本月盈亏综合考虑系统具有下面8项功能模块增加人员,删除人员,修改人员,查询本月经营信息,基础数据设置,数据存盘,数据装入系统使用的数据文件格式如下Base.___格式项目数据经理固定月薪3000销售经理固定月薪1000销售经理提成%1销售人员提成%2技术人员小时工资20ID6Person.___(格式编号姓名人员类别其它数据销售员销售额技术人员工作小时)2wang3_____03liu14wu41005huang26tao3150000注人员类型编号1-经理;2-销售经理;3-销售员;4-技术人员
3、系统设计
1.系统总体框架使用面向对象的程序设计思想进行分析,整个系统涉及两大类信息和操作,公司,人员所以系统主要涉及两个大类公司类Company、人员类Person系统的总体框架就是公司类,人员类的定义;主函数中定义一个公司对象,循环显示主菜单并根据用户选择调用公司类的相应方法成员函数1公司类Company考虑系统操作的人员信息的数量具有不确定性,所以考虑使用链表保存、处理人员信息公司类包含所有人员信息的一个不带头结点的链表(作为数据成员)及可以对人员信息进行增,删,改,查询经营信息,基础数据设置,数据存盘,数据装入等操作的相关模块AddDeleteModifyQuerySetS__eLoad作为成员函数2人员类Person所有人员都具有的公共信息及操作可以使用人员类进行描述由于系统具有4类人员且4类人员数据,操作有所不同,如销售员包含销售额,而技术人员包含工作小时数且计算工资的方法不同,所以应当为4类人员创建相应的Person类的派生类3为了使公司类可以方便处理人员信息,可以考虑将公司类确定为人员类的友元类或者人员类提供公共的方法以便公司类进行操作为了公司类可以用共同方法操作人员类,可以将人员类的方法确定为虚函数
2.类的层次图Person{NoNameDutyEarningnextPersonCalcSalaryOutput}__nagerSalesSale__anagerTechnician{__nager{Amount{Amount{tCalcSalarySalesGetAmountSale__anagerTechnicianOutput}SetAmountSetAmountGetTSetTCalcSalaryCalcSalaryCalcSalaryOutput}Output}Output}其中
(1)Person类的No-人员编号,Name-人员姓名,Duty-人员类别,Earning-工资,next-指向下一个人员的指针;Person类的CalcSalary,Output定义为纯虚函数分别表示要计算人员工资和输出人员信息由于定义纯虚函数,所以Person是抽象类,具体计算工资,输出人员信息由派生类完成
(2)各个派生的类,包含本类对象特有的数据,Sales::Amount-销售员销售额,Sale__anager::Amount-销售经理的总销售额(系统统计各个销售员销售额得到销售经理的总销售额),Technician::t-技术人员工作小时数Company{Person*WorkerClearCompany~CompanyAddDeleteModifyQuerySetS__eLoad}其中
(1)Worker就是人员链表
(2)Clear用于清除人员链表所有结点
(3)AddDeleteModifyQuerySetS__eLoad分别表示系统各个功能模块:增加人员,删除人员,修改人员,查询本月经营信息,基础数据设置,数据存盘,数据装入
3.系统关键算法流程图1主函数流程2Company::Add3Company::Delete4Company::Modify5Company::Query6Company::S__e7Company::Load
4、源程序清单参见附录
5、系统测试(列出各功能具体的输入数据及对应的输出结果,说明其是否符合设计要求)
6、小结设计过程心得体会附录/*本程序有关的两个数据文件base.___-基础数据文件必须存在,且按规定格式保存person.___-人员信息文件可选*/#includeiostream.h#includefstream.h#includectype.h#includestring.h//全局数据,对象double__nagerSalary;//经理固定月薪doubleSale__anagerSalary;//销售经理固定月薪doubleSale__anagerPer__nt;//销售经理提成%doubleSalesPer__nt;//销售人员提成%doubleWagePerHour;//技术人员小时工资intID;//员工标识要保证唯一classPerson//员工类{protected:intNo;//编号charName
[20];//姓名intDuty;//岗位doubleEarning;//收入Person*next;public:PersoncharIDchar*NameintDuty{this-Duty=Duty;strcpythis-NameName;this-No=ID;}virtualvoidCalcSalary=0;virtualvoidOutput=0;friendclassCompany;};class__nager:publicPerson//经理类{public:__nagercharIDchar*NameintDuty:PersonIDNameDuty{}voidCalcSalary{Earning=__nagerSalary;}voidOutput{CalcSalary;coutNo\tName\t经理\tEarningendl;}};classSale__anager:publicPerson//销售经理类{private:doubleAmount;public:Sale__anagercharIDchar*NameintDuty:PersonIDNameDuty{}voidSetAmountdoubles{Amount=s;}voidCalcSalary{Earning=Sale__anagerSalary+Amount*Sale__anagerPer__nt/100;}voidOutput{CalcSalary;coutNo\tName\t销售经理\tEarningendl;}};classTechnician:publicPerson//技术员类{private:doublet;public:TechniciancharIDchar*NameintDutydoubleT:PersonIDNameDuty{this-t=T;}doubleGetT{returnt;}voidSetTdoubleT{this-t=T;}voidCalcSalary{Earning=WagePerHour*t;}voidOutput{CalcSalary;coutNo\tName\t技术员\tt\tEarningendl;}};classSales:publicPerson//销售员类{private:doubleAmount;public:SalescharIDchar*NameintDutydoubleAmount:PersonIDNameDuty{this-Amount=Amount;}doubleGetAmount{returnAmount;}voidSetAmountdoubleAmount{this-Amount=Amount;}voidCalcSalary{Earning=SalesPer__nt/100*Amount;}voidOutput{CalcSalary;coutNo\tName\t销售员\tAmount\tEarningendl;}};classCompany//公司类{private:Person*Worker;//员工表voidClear;//清除内存中数据public:Company{Worker=0;Load;}~Company{Person*p;p=Worker;whilep{p=p-next;deleteWorker;Worker=p;}Worker=0;}voidAdd;//增加人员voidDelete;//删除人员voidModify;//修改人员voidQuery;//查询人员voidSet;//基础数据设置voidS__e;//数据存盘包括基础数据,人员数据voidLoad;//数据装入包括基础数据,人员数据};voidCompany::Clear//清除内存中人员数据内部使用{Person*p=Worker;whilep{Worker=p-next;deletep;p=Worker;}}voidCompany::Add{Person*p;//新结点指针intDuty;charName
[20];doubleAmountT;cout\n**新增员工**\n;//输入员工信息ID++;cout输入岗位1-经理2-销售经理3-销售员4-技术员:;cinDuty;cout输入姓名:;cinName;ifDuty==3{cout本月销售额:;cinAmount;}elseifDuty==4{cout本月工作小时数0-168:;cinT;}//创建新员工结点switchDuty{case1:p=new__nagerIDNameDuty;break;case2:p=newSale__anagerIDNameDuty;break;case3:p=newSalesIDNameDutyAmount;break;case4:p=newTechnicianIDNameDutyT;break;}p-next=0;//员工结点加入链表ifWorker//若已经存在结点{Person*p2;p2=Worker;whilep2-next//查找尾结点{p2=p2-next;}p2-next=p;//连接}else//若不存在结点表空{Worker=p;//连接}}voidCompany::Delete//删除人员{intNo;cout\n**删除员工**\n;coutID:;cinNo;//查找要删除的结点Person*p1*p2;p1=Worker;whilep1{ifp1-No==Nobreak;else{p2=p1;p1=p1-next;}}//删除结点ifp1!=NULL//若找到结点,则删除{ifp1==Worker//若要删除的结点是第一个结点{Worker=p1-next;deletep1;}else//若要删除的结点是后续结点{p2-next=p1-next;deletep1;}cout找到并删除\n;}else//未找到结点cout未找到!\n;}voidCompany::Modify{intNoDuty;charName
[20];doubleAmountT;cout\n**修改员工**\n;coutID:;cinNo;//查找要修改的结点Person*p1*p2;p1=Worker;whilep1{ifp1-No==Nobreak;else{p2=p1;p1=p1-next;}}//修改结点ifp1!=NULL//若找到结点{p1-Output;cout调整岗位1-经理2-销售经理3-销售员4-技术员:;cinDuty;ifp1-Duty!=Duty//若岗位发生变动{//修改其它数据cout输入姓名:;cinName;ifDuty==3{cout本月销售额:;cinAmount;}elseifDuty==4{cout本月工作小时数0-168:;cinT;}//创建新员工结点Person*p3;switchDuty{case1:p3=new__nagerp1-NoNameDuty;break;case2:p3=newSale__anagerp1-NoNameDuty;break;case3:p3=newSalesp1-NoNameDutyAmount;break;case4:p3=newTechnicianp1-NoNameDutyT;break;}//员工结点替换到链表p3-next=p1-next;ifp1==Worker//若要替换的结点是第一个结点Worker=p3;else//若要删除的结点是后续结点p2-next=p3;//删除原来的员工结点deletep1;}else//若岗位没有变动{cout输入姓名:;cinp1-Name;ifDuty==3{cout本月销售额:;cinAmount;Sales*p1-SetAmountAmount;}elseifDuty==4{cout本月工作小时数0-168:;cinT;Technician*p1-SetTT;}}cout修改成功!\n;}else//未找到结点cout未找到!\n;}voidCompany::Query{cout\n**查询人员本月销售信息**\n;doublesum=0;//销售额总和Person*p=Worker;whilep{ifp-Duty==3sum+=Sales*p-GetAmount;p=p-next;}p=Worker;doublesum2=0;//工资总和whilep{ifp-Duty==2Sale__anager*p-SetAmountsum;p-Output;sum2+=p-Earning;p=p-next;}cout本月盈利:sum*
0.20-sum2endl;cout按照20%利润计算\n;}voidCompany::Set{cout\n**设置基础数据**\n;cout经理固定月薪[__nagerSalary元]:;cin__nagerSalary;cout销售经理固定月薪[Sale__anagerSalary元]:;cinSale__anagerSalary;cout销售经理提成[Sale__anagerPer__nt%]:;cinSale__anagerPer__nt;cout销售人员提成[SalesPer__nt%]:;cinSalesPer__nt;cout技术人员小时工资[WagePerHour元/小时]:;cinWagePerHour;cout员工标识[=ID]:;cinID;}voidCompany::S__e//数据存盘包括基础数据,人员数据均采用文本文件{ofstreamfPersonfBase;charc;cout\n保存人员和基础数据是否继续[Y/N]:;cinc;iftoupperc!=Yreturn;//保存人员编号、姓名、岗位fPerson.openperson.___ios::out;Person*p=Worker;whilep{fPersonp-No\tp-Name\tp-Duty\t;ifp-Duty==3fPersonSales*p-GetAmount\t;elseifp-Duty==4fPersonTechnician*p-GetT\t;fPersonendl;p=p-next;}fPerson.close;//保存基础数据fBase.openbase.___ios::out;fBase经理固定月薪\t__nagerSalaryendl;fBase销售经理固定月薪\tSale__anagerSalaryendl;fBase销售经理提成%\tSale__anagerPer__ntendl;fBase销售人员提成%\tSalesPer__ntendl;fBase技术人员小时工资\tWagePerHourendl;fBaseID\tIDendl;fPerson.close;cout\n保存人员和基础数据已经完成...\n;}voidCompany::Load//数据装入包括基础数据,人员数据{//基础数据装入ifstreamfBase;charbuf
[80];//buf用于保存数据文件中的注释字符串fBase.openbase.___ios::in;fBasebuf__nagerSalary;//经理固定月薪fBasebufSale__anagerSalary;//销售经理固定月薪fBasebufSale__anagerPer__nt;//销售经理提成%fBasebufSalesPer__nt;//销售人员提成%fBasebufWagePerHour;//技术人员小时工资fBasebufID;//员工标识fBase.close;//清除内存人员数据Clear;//人员数据数据装入ifstreamfPerson;Person*p=Worker;intNo;charName
[20];intDuty;doubleAmountT;fPerson.openperson.___ios::in;//读一条记录fPersonNoNameDuty;ifDuty==3fPersonAmount;elseifDuty==4fPersonT;whilefPerson.good{//创建员工结点switchDuty{case1:p=new__nagerNoNameDuty;break;case2:p=newSale__anagerNoNameDuty;break;case3:p=newSalesNoNameDutyAmount;break;case4:p=newTechnicianNoNameDutyT;break;}p-next=0;//员工结点加入链表ifWorker//若已经存在结点{Person*p2;p2=Worker;whilep2-next//查找尾结点{p2=p2-next;}p2-next=p;//连接}else//若不存在结点表空{Worker=p;//连接}//读下一条记录fPersonNoNameDuty;ifDuty==3fPersonAmount;elseifDuty==4fPersonT;}fPerson.close;cout\n人员和基础数据已经装入...\n;}void__in{charc;Companya;do{cout\n***公司人员管理系统***\n;cout1-增加人员\n;cout2-删除人员\n;cout3-修改人员\n;cout4-查询本月经营信息\n;cout5-基础数据设置\n;cout6-数据存盘\n;cout7-数据装入\n;cout8-退出\t请选择1-8:;cinc;switchc{case1:a.Add;break;case2:a.Delete;break;case3:a.Modify;break;case4:a.Query;break;case5:a.Set;break;case6:a.S__e;break;case7:a.Load;break;}}whilec!=8;}。