- 218.19 KB
- 2022-05-14 15:54:55 发布
- 1、本文档共5页,可阅读全部内容。
- 2、本文档内容版权归属内容提供方,所产生的收益全部归内容提供方所有。如果您对本文有版权争议,可选择认领,认领后既往收益都归您。
- 3、本文档由用户上传,本站不保证质量和数量令人满意,可能有诸多瑕疵,付费之前,请仔细先通过免费阅读内容等途径辨别内容交易风险。如存在严重挂羊头卖狗肉之情形,可联系本站下载客服投诉处理。
- 文档侵权举报电话:19940600175。
《程序设计基础》(C++)课程设计报告公司人员管理系统名:号:指导教师:成绩:完成时间:完成地点:精选范本
一、设计题目(问题)描述和要求1.题目:公司人员管理系统2.问题描述:某小型公司,主要有四类人员:经理、兼职技术人员、销售经理和兼职推销员。现在,需要存储这些人员的姓名、编号、级别、当月薪水,计算月薪总额并显示全部信息。要求:(1)其中,人员编号在生成人员信息时同时生成,每输入一个人员信息编号顺序加1。(2)程序对所有人员有提升级别的功能(3)月薪的计算方法是:经理拿固定月薪,兼职技术人员按工作小时数领取月薪,兼职推销员的报酬按该推销员当月销售额提成,销售经理既拿固定月薪也领取销售提成。(4)能按姓名或者编号显示、查找、增加、删除和保存各类人员的信息二、系统分析与模块设计根据问题描述和要求,系统要求能够按姓名或者编号显示、查找、增加、删除和保存各类人员的信息。确定程序至少应该具备如下功能:“查询人员”、“增加人员”、“删除人员”、“数据存盘”基本模块。系统既然具有“数据存盘”功能-人员数据可以保存到磁盘文件,那么也就意味着今后可以从磁盘文件读出人员数据,所以系统增加了“人员数据装入”模块,以方便用户使用、避免数据重复录入。考虑到系统实现简捷,人员数据文件采用文本文件,人员数据文件名:Person.txt。做为一个完整系统,除了具有增加人员,删除人员信息模块,还应该具有修改人员相关信息的功能,所以本系统设计时考虑增加“修改人员”模块。考虑到根据编号查找人员信息功能在“删除人员”、“修改人员”等模块都使用,所以可以考虑设置为一个模块。考虑到系统要求人员编号在生成人员信息时同时生成,每输入一个人员信息编号顺序加1。这样就要求人员编号在增加人员时自动生成(增加1)且不重复。根据这个要求,可以考虑设置一个全局量:“当前最大编号”,每增加一个人员,精选范本
当前最大编号自动增1,然后新增加人员使用这个编号。为了保证系统能记忆这个编号,可以使用一个数据文件保存当前这个编号。系统每次开始运行前从文件读入这个编号,随着人员增加,编号自动增加,系统每次运行结束时将这个编号写入文件。本系统将初值(没有一个用户时)设置为00考虑到人员的许多固定信息如:经理、销售经理的固定月薪,销售经理、销售人员提成,技术人员小时工资等都是一些不需要每个人员都要输入的信息,所以可以将这些信息都保存在一个数据文件中,本系统为了方便起见,将这些信息与“最大编号”全部保存在一个文件中,并使用“基础数据设置”模块进行设置和管理。基础数据文件也采用文本文件,基础数据文件名:Base.txt。本系统还提供“查询本月经营信息”帮助计算销售总额,工资总额,并按照公式计算本月盈亏。综合考虑系统具有下面8项功能模块:增加人员,删除人员,修改人员,查询本月经营信息,基础数据设置,数据存盘,数据装入。系统使用的数据文件格式如下:Base.txt:(格式:项目数据)经理固定月薪3000销售经理固定月薪1000销售经理提成%1销售人员提成%2技术人员小时工资20ID6Person.txt:(格式:编号,姓名,人员类别,其它数据,销售员销售额,技术人员工作小时)2wang31000003liu14wu41005huang26tao3150000注:人员类型编号1—经理;2—销售经理;3—销售员;4—技术人员二、系统设计1.系统总体框架使用面向对象的程序设计思想进行分析,整个系统涉及两大类信息和操作,公司,人员。所以系统主要涉及两个大类:公司类Company人员类Person。系精选范本
统的总体框架就是公司类,人员类的定义;主函数中定义一个公司对象,循环显示主菜单并根据用户选择调用公司类的相应方法(成员函数)。(1)公司类Company考虑系统操作的人员信息的数量具有不确定性,所以考虑使用链表保存、处理人员信息。公司类包含:所有人员信息的一个不带头结点的链表(作为数据成员)及可以对人员信息进行增,删,改,查询经营信息,基础数据设置,数据存盘,数据装入等操作的相关模块(Add,Delete,Modify,Query,Set,Save,Load)作为成员函数。(2)人员类Person:所有人员都具有的公共信息及操作可以使用人员类进行描述。由于系统具有4类人员且4类人员数据,操作有所不同,如销售员包含销售额,而技术人员包含工作小时数且计算工资的方法不同,所以应当为4类人员创建相应的Person类的派生类。⑶为了使公司类可以方便处理人员信息,可以考虑将公司类确定为人员类的友元类或者人员类提供公共的方法以便公司类进行操作。为了公司类可以用共同方法操作人员类,可以将人员类的方法确定为虚函数。1.类的层次图Person{No,Name,Duty,Earning,next,Person(),CalcSalary(),Output()}{Manager。,{Amount,{Amount,{t,CalcSalary(),Sales(),GetAmount(),SalesManager(),Technician。,Output()}SetAmount(),SetAmount(),GetT(),SetT(),CalcSalary(),CalcSalary(),CalcSalary(),TechnicianOutput。}Output()}Output。}其中:(1)Person类的No-人员编号,Name人员姓名,Duty-人员类别,Earning-X资,next-指向下一个人员的指针;Person类的CalcSalary(),Output()定义为纯虚函数分别表示要计算人员工资和输出人员信息,由于定义纯虚函数,所以Person是抽象类,具体计算工资,输出人员信息由派生类完成。(2)各个派生的类,包含本类对象特有的数据,Sales::Amount-销售员销售额,精选范本
SalesManager::Amount-销售经理的总销售额(系统统计各个销售员销售额得到销售经理的总销售额),Techniciana-技术人员工作小时数。Company{Person*Worker,Clear(),CompanyO,~CompanyO,Add(),DeleteO,ModifyO,QueryO,Set(),SaveO,Load()}其中:(1)Worker就是人员链表。(2)Clear()用于清除人员链表所有结点。(3)Add(),Delete(),Modify(),Query(),Set(),Save(),Load()分别表示系统各个功能模块:增加人员,删除人员,修改人员,查询本月经营信息,基础数据设置,数据存盘,数据装入。3.系统关键算法流程图(1)主函数流程(开始:创建公司对象4显示菜单接受输入I根据输入执行公司操作退出结束精选范本
(2)Company::Add()(3)Company二Delete()(4)Company二Modify精选范本
(5)Company二Query()精选范本(5)Company二Query()遍历统计销售额遍历统计工资总额计算盈亏打印本月经营信息[结束:,(6)Company::Save()精选范本
⑺Company二Load()四、源程序清单参见附录五、系统测试(列出各功能具体的输入数据及对应的输出结果,说明其是否符合设计要求)六、小结(设计过程心得体会)精选范本
附录:/*本程序有关的两个数据文件:base.txt一基础数据文件(必须存在,且按规定格式保存)person.txt—人员信息文件(可选)*/#include#include#include#include//全局数据,对象doubleManagerSalary;//经理固定月薪doubleSalesManagerSalary;//销售经理固定月薪doubleSalesManagerPercent;/B售经理提成%doubleSalesPercent;//销售人员提成%doubleWagePerHour;intID;//技术人员小时工资//员工标识(要保证唯一)classPerson//员工类{protected:intNo;〃编号charName[20];//姓名intDuty;〃岗位doubleEarning;/收入Person*next;public:Person(charID,char*Name,intDuty){this->Duty=Duty;strcpy(this->Name,Name);this->No=ID;}virtualvoidCalcSalary()=0;virtualvoidOutput()=0;friendclassCompany;};classManagerpublicPerson〃经理类{public:Manager(charID,char*Name,intDuty):Person(ID,Name,Duty)。voidCalcSalary(){Earning=ManagerSalary;}voidOutput(){CalcSalary();cout<t=T;}doubleGetT(){returnt;}voidSetT(doubleT){this->t=T;}voidCalcSalary(){Earning=WagePerHour*t;}voidOutput(){CalcSalary();cout<Amount=Amount;}doubleGetAmount(){returnAmount;}voidSetAmount(doubleAmount){this->Amount=Amount;}voidCalcSalary(){Earning=SalesPercent/100*Amount;}voidOutput(){CalcSalary();cout<next;deleteWorker;Worker=p;}Worker=0;}voidAdd();//增加人员voidDelete();〃删除人员精选范本
voidModify();〃修改人员voidQuery();〃查询人员voidSet();//基础数据设置voidSave();//数据存盘(包括基础数据,人员数据)voidLoad();//数据装入(包括基础数据,人员数据)};voidCompany::Clear()〃清除内存中人员数据(内部使用){Person*p=Worker;while(p){Worker=p->next;deletep;p=Worker;}}voidCompany::Add(){Person*p;//新结点指针intDuty;charName[20];doubleAmount,T;cout<<"n**新增员工**n”;//输入员工信息ID++;cout<<"输入岗位(1-经理2-销售经理3-销售员4-技术员):";cin>>Duty;cout<<"输入姓名:";cin>>Name;if(Duty==3){cout<<”本月销售额:";cin>>Amount;}elseif(Duty==4){cout<<"本月工作小时数(0-168):";cin>>T;}//创建新员工结点switch(Duty){case1:p=newManager(ID,Name,Duty);break;case2:p=newSalesManager(ID,Name,Duty);break;case3:p=newSales(ID,Name,Duty,Amount);break;case4:p=newTechnician(ID,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;//连接}}voidCompany二Delete()〃删除人员{intNo;cout<<"n**删除员工**n";cout<<"ID:";cin>>No;//查找要删除的结点Person*p1,*p2;p1=Worker;while(pl){if(p1->No==No)break;else{p2=p1;p1=p1->next;}}//删除结点if(p1!=NULL)//若找到结点,则删除{if(p1==Worker)//若要删除的结点是第一个结点{Worker=p1->next;deletep1;}else//若要删除的结点是后续结点{p2->next=p1->next;精选范本
deletep1;}cout<<"找到并删除n";}else//未找到结点cout<<"未找至U!n";}voidCompany二Modify(){intNo,Duty;charName[20];doubleAmount,T;cout<<"n**修改员工**n”;cout<<"ID:";cin>>No;//查找要修改的结点Person*p1,*p2;p1=Worker;while(pl){if(p1->No==No)break;else{p2=p1;p1=p1->next;}}//修改结点if(p1!=NULL)//若找到结点{p1->Output();cout<<"调整岗位(1-经理2-销售经理3-销售员4-技术员):";cin>>Duty;if(p1->Duty!=Duty)//若岗位发生变动{//修改其它数据cout<<"输入姓名:";cin>>Name;if(Duty==3){cout<<”本月销售额:";cin>>Amount;}elseif(Duty==4){cout<<"本月工作小时数(0-168):";精选范本
cin>>T;}//创建新员工结点Person*p3;switch(Duty){case1:p3=newManager(p1->No,Name,Duty);break;case2:p3=newSalesManager(p1->No,Name,Duty);break;case3:p3=newSales(p1->No,Name,Duty,Amount);break;case4:p3=newTechnician(p1->No,Name,Duty,T);break;}//员工结点替换到链表p3->next=p1->next;if(p1==Worker)//若要替换的结点是第一个结点Worker=p3;else//若要删除的结点是后续结点p2->next=p3;//删除原来的员工结点deletep1;}else//若岗位没有变动{cout<<"输入姓名:";cin>>p1->Name;if(Duty==3){cout<<”本月销售额:";cin>>Amount;((Sales*)p1)->SetAmount(Amount);}elseif(Duty==4){cout<<"本月工作小时数(0-168):";cin>>T;((Technician*)p1)->SetT(T);}}cout<<"修改成功!n";}else//未找到结点cout<<"未找至U!n";}voidCompany二Query(){cout<<"n**查询人员本月销售信息**n";doublesum=0;//销售额总和Person*p=Worker;while(p){精选范本
if(p->Duty==3)sum+=((Sales*)p)->GetAmount();p=p->next;}p=Worker;doublesum2=0;//工资总和while(p){if(p->Duty==2)((SalesManager*)p)->SetAmount(sum);p->Output();sum2+=p->Earning;p=p->next;}cout<<"本月盈利J:"<>ManagerSalary;cout<<”销售经理固定月薪["<>SalesManagerSalary;cout<<”销售经理提成["<>SalesManagerPercent;cout<<”销售人员提成["<>SalesPercent;cout<<”技术人员小时工资["<>WagePerHour;cout<<"员工标识[>="<>ID;}voidCompany::Save()//数据存盘(包括基础数据,人员数据),均采用文本文件{ofstreamfPerson,fBase;charc;cout<<"n保存人员和基础数据,是否继续?[Y/N]:";cin>>c;if(toupper(c)!="Y")return;//保存人员编号、姓名、岗位fPerson.open("person.txt",ios二out);Person*p=Worker;while(p)精选范本
{fPerson<No<<"t"<Name<<"t"<Duty<<"t";精选范本
if(p->Duty==3)fPerson<<((Sales*)p)->GetAmount()<<"t";elseif(p->Duty==4)fPerson<<((Technician*)p)->GetT()<<"t";fPerson<next;}fPerson.close();//保存基础数据fBase.open("base.txt",ios二out);fBase<<”经理固定月薪t"<>buf>>ManagerSalary;//销售人员提成%//技术人员小时工资//员工标识fBase>>buf>>SalesManagerSalary;〃销售经理固定月薪fBase>>buf>>SalesManagerPercent;销售经理提成%fBase>>buf>>SalesPercent;fBase>>buf>>WagePerHour;fBase>>buf>>ID;fBase.close();//清除内存人员数据Clear();//人员数据数据装入ifstreamfPerson;Person*p=Worker;intNo;charName[20];intDuty;doubleAmount,T;fPerson.open("person.txt",ios::in);//读一条记录fPerson>>No>>Name>>Duty;if(Duty==3)fPerson>>Amount;elseif(Duty==4)fPerson>>T;精选范本
while(fPerson.good()){//创建员工结点switch(Duty){case1:p=newManager(No,Name,Duty);break;case2:p=newSalesManager(No,Name,Duty);break;case3:p=newSales(No,Name,Duty,Amount);break;case4:p=newTechnician(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;//连接}//读下一条记录fPerson>>No>>Name>>Duty;if(Duty==3)fPerson>>Amount;elseif(Duty==4)fPerson>>T;}fPerson.close();cout<<"n人员和基础数据已经装入…n";}voidmain(){charc;Companya;do{cout<<"n***公司人员管理系统***n";cout<<"1一增加人员n";cout<<"2一删除人员n";cout<<"3一修改人员n";cout<<"4一查询本月经营信息n”;精选范本
cout<<"5一基础数据设置n";cout<<"6一数据存盘n";cout<<"7一数据装入n";cout<<"8—退出t请选择(1-8):";cin>>c;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");}精选范本