《C++课程设计公司人员管理系统讲课讲稿.doc》由会员分享,可在线阅读,更多相关《C++课程设计公司人员管理系统讲课讲稿.doc(46页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、Good is good, but better carries it.精益求精,善益求善。C+课程设计公司人员管理系统-课程设计报告公司人员管理系统课程:面向对象课程设计班级:091022学号:09102220姓名:李良一、 指导老师:丁木华二一一年十二月十八日设计题目(问题)描述和要求1 题目:公司人员管理系统2 问题描述:某小型公司,主要有四类人员:经理、兼职技术人员、销售经理和兼职推销员。现在,需要存储这些人员的姓名、编号、级别、当月薪水,计算月薪总额并显示全部信息。要求:(1) 其中,人员编号在生成人员信息时同时生成,每输入一个人员信息编号顺序加1。(2) 程序对所有人员有提升级别的
2、功能(3) 月薪的计算方法是:经理拿固定月薪,兼职技术人员按工作小时数领取月薪,兼职推销员的报酬按该推销员当月销售额提成,销售经理既拿固定月薪也领取销售提成。二、 能按姓名或者编号显示、查找、增加、删除和保存各类人员的信息系统分析与模块设计根据问题描述和要求,系统要求能够按姓名或者编号显示、查找、增加、删除和保存各类人员的信息。确定程序至少应该具备如下功能:“查询人员”、“增加人员”、“删除人员”、“数据存盘”基本模块。系统既然具有“数据存盘”功能人员数据可以保存到磁盘文件,那么也就意味着今后可以从磁盘文件读出人员数据,所以系统增加了“人员数据装入”模块,以方便用户使用、避免数据重复录入。考虑
3、到系统实现简捷,人员数据文件采用文本文件,人员数据文件名:Person.txt。做为一个完整系统,除了具有增加人员,删除人员信息模块,还应该具有修改人员相关信息的功能,所以本系统设计时考虑增加“修改人员”模块。考虑到根据编号查找人员信息功能在“删除人员”、“修改人员”等模块都使用,所以可以考虑设置为一个模块。考虑到系统要求人员编号在生成人员信息时同时生成,每输入一个人员信息编号顺序加1。这样就要求人员编号在增加人员时自动生成(增加1)且不重复。根据这个要求,可以考虑设置一个全局量:“当前最大编号”,每增加一个人员,当前最大编号自动增1,然后新增加人员使用这个编号。为了保证系统能记忆这个编号,可
4、以使用一个数据文件保存当前这个编号。系统每次开始运行前从文件读入这个编号,随着人员增加,编号自动增加,系统每次运行结束时将这个编号写入文件。本系统将初值(没有一个用户时)设置为0。考虑到人员的许多固定信息如:经理、销售经理的固定月薪,销售经理、销售人员提成,技术人员小时工资等都是一些不需要每个人员都要输入的信息,所以可以将这些信息都保存在一个数据文件中,本系统为了方便起见,将这些信息与“最大编号”全部保存在一个文件中,并使用“基础数据设置”模块进行设置和管理。基础数据文件也采用文本文件,基础数据文件名:Base.txt。本系统还提供“查询本月经营信息”帮助计算销售总额,工资总额,并按照公式计算
5、本月盈亏。综合考虑系统具有下面8项功能模块:增加人员,删除人员,修改人员,查询本月经营信息,基础数据设置,数据存盘,数据装入。系统使用的数据文件格式如下:Base.txt:(格式:项目数据)经理固定月薪3000销售经理固定月薪1000销售经理提成1销售人员提成2技术人员小时工资20ID6Person.txt:(格式:编号,姓名,人员类别,其它数据,销售员销售额,技术人员工作小时)2wang31000003liu14wu41005huang26tao3150000注:人员类型编号1经理;2销售经理;3销售员;4技术人员三、 系统设计1. 系统总体框架使用面向对象的程序设计思想进行分析,整个系统涉
6、及两大类信息和操作,公司,人员。所以系统主要涉及两个大类:公司类Company、人员类Person。系统的总体框架就是公司类,人员类的定义;主函数中定义一个公司对象,循环显示主菜单并根据用户选择调用公司类的相应方法(成员函数)。(1)公司类Company:考虑系统操作的人员信息的数量具有不确定性,所以考虑使用链表保存、处理人员信息。公司类包含:所有人员信息的一个不带头结点的链表(作为数据成员)及可以对人员信息进行增,删,改,查询经营信息,基础数据设置,数据存盘,数据装入等操作的相关模块(Add,Delete,Modify,Query,Set,Save,Load)作为成员函数。(2)人员类Per
7、son:所有人员都具有的公共信息及操作可以使用人员类进行描述。由于系统具有4类人员且4类人员数据,操作有所不同,如销售员包含销售额,而技术人员包含工作小时数且计算工资的方法不同,所以应当为4类人员创建相应的Person类的派生类。(3)为了使公司类可以方便处理人员信息,可以考虑将公司类确定为人员类的友元类或者人员类提供公共的方法以便公司类进行操作。为了公司类可以用共同方法操作人员类,可以将人员类的方法确定为虚函数。类的层次图PersonNo,Name,Duty,Earning,next,Person(),CalcSalary(),Output()ManagerSalesSalesManager
8、TechnicianManager(),Amount,Amount,t,CalcSalary(),Sales(),GetAmount(),SalesManager(),Technician(),Output()SetAmount(),SetAmount(),GetT(),SetT(),CalcSalary(),CalcSalary(),CalcSalary(),Output()Output()Output()其中:(1)Person类的No-人员编号,Name-人员姓名,Duty-人员类别,Earning-工资,next-指向下一个人员的指针;Person类的CalcSalary(),Outp
9、ut()定义为纯虚函数分别表示要计算人员工资和输出人员信息,由于定义纯虚函数,所以Person是抽象类,具体计算工资,输出人员信息由派生类完成。(2)各个派生的类,包含本类对象特有的数据,Sales:Amount-销售员销售额,SalesManager:Amount-销售经理的总销售额(系统统计各个销售员销售额得到销售经理的总销售额),Technician:t-技术人员工作小时数。CompanyPerson*Worker,Clear(),Company(),Company(),Add(),Delete(),Modify(),Query(),Set(),Save(),Load()其中:(1)Wo
10、rker就是人员链表。(2)Clear()用于清除人员链表所有结点。(3)Add(),Delete(),Modify(),Query(),Set(),Save(),Load()分别表示系统各个功能模块:增加人员,删除人员,修改人员,查询本月经营信息,基础数据设置,数据存盘,数据装入。系统关键算法流程图(1)主函数流程(2)Company:Add()(3)Company:Delete()(4)Company:Modify四、 (5)Company:Query()(6)Company:Save()(7)Company:Load()源程序清单参见附录五、 系统测试小结通过程序设计,我能够基本掌握C+
11、程序设计的方法,并且在此基础上掌握类的构造方法,明确类中构造函数、成员函数的建立以及调用,此外,并且,结合C+中字符串函数的编译系统给定的库函数,采用一定的逻辑编译,实现题目中要求的各项要求,达到基本实验目的,提高自己的C+语言使用水平。六、 参考文献【1】陈维兴,林小茶.C+面向对象程序设计教程.北京.清华大学出版社2010,10【2】谭浩强.C语言程序设计.北京:清华大学出版社.2010,5附录:/*本程序有关的两个数据文件:base.txt基础数据文件(必须存在,且按规定格式保存)person.txt人员信息文件(可选)*/#include#include#include#include
12、/全局数据,对象doubleManagerSalary;/经理固定月薪doubleSalesManagerSalary;/销售经理固定月薪doubleSalesManagerPercent;/销售经理提成doubleSalesPercent;/销售人员提成doubleWagePerHour;/技术人员小时工资intID;/员工标识(要保证唯一)classPerson/员工类protected:intNo;/编号charName20;/姓名intDuty;/岗位doubleEarning;/收入Person*next;public:Person(charID,char*Name,intDuty)
13、this-Duty=Duty;strcpy(this-Name,Name);this-No=ID;virtualvoidCalcSalary()=0;virtualvoidOutput()=0;friendclassCompany;classManager:publicPerson/经理类public:Manager(charID,char*Name,intDuty):Person(ID,Name,Duty)voidCalcSalary()Earning=ManagerSalary;voidOutput()CalcSalary();coutNotNamet经理tEarningendl;clas
14、sSalesManager:publicPerson/销售经理类private:doubleAmount;public:SalesManager(charID,char*Name,intDuty):Person(ID,Name,Duty)voidSetAmount(doubles)Amount=s;voidCalcSalary()Earning=SalesManagerSalary+Amount*SalesManagerPercent/100;voidOutput()CalcSalary();coutNotNamet销售经理tEarningt=T;doubleGetT()returnt;voi
15、dSetT(doubleT)this-t=T;voidCalcSalary()Earning=WagePerHour*t;voidOutput()CalcSalary();coutNotNamet技术员tttEarningAmount=Amount;doubleGetAmount()returnAmount;voidSetAmount(doubleAmount)this-Amount=Amount;voidCalcSalary()Earning=SalesPercent/100*Amount;voidOutput()CalcSalary();coutNotNamet销售员tAmounttEar
16、ningnext;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;
17、/新结点指针intDuty;charName20;doubleAmount,T;coutn*新增员工*n;/输入员工信息ID+;coutDuty;coutName;if(Duty=3)coutAmount;elseif(Duty=4)coutT;/创建新员工结点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,
18、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;coutn*删除员工*n;coutNo;/查找要删除的结点Person*p1,*p2;p1=Worker;while(p1)if(p1-No=No)break;elsep2=p1;p1=p1-next;/删除结点if(p1!=NULL)/若找到结点,则删除
19、if(p1=Worker)/若要删除的结点是第一个结点Worker=p1-next;deletep1;else/若要删除的结点是后续结点p2-next=p1-next;deletep1;cout找到并删除n;else/未找到结点cout未找到!n;voidCompany:Modify()intNo,Duty;charName20;doubleAmount,T;coutn*修改员工*n;coutNo;/查找要修改的结点Person*p1,*p2;p1=Worker;while(p1)if(p1-No=No)break;elsep2=p1;p1=p1-next;/修改结点if(p1!=NULL)/
20、若找到结点p1-Output();coutDuty;if(p1-Duty!=Duty)/若岗位发生变动/修改其它数据coutName;if(Duty=3)coutAmount;elseif(Duty=4)coutT;/创建新员工结点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(
21、p1-No,Name,Duty,T);break;/员工结点替换到链表p3-next=p1-next;if(p1=Worker)/若要替换的结点是第一个结点Worker=p3;else/若要删除的结点是后续结点p2-next=p3;/删除原来的员工结点deletep1;else/若岗位没有变动coutp1-Name;if(Duty=3)coutAmount;(Sales*)p1)-SetAmount(Amount);elseif(Duty=4)coutT;(Technician*)p1)-SetT(T);cout修改成功!n;else/未找到结点cout未找到!n;voidCompany:Qu
22、ery()coutDuty=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本月盈利:sum*0.20-sum2endl;cout(按照20利润计算)n;voidCompany:Set()coutn*设置基础数据*n;cout经理固定月薪ManagerSalaryManagerSalary;cout销售经理固定月薪SalesMa
23、nagerSalarySalesManagerSalary;cout销售经理提成SalesManagerPercentSalesManagerPercent;cout销售人员提成SalesPercentSalesPercent;cout技术人员小时工资WagePerHourWagePerHour;cout=IDID;voidCompany:Save()/数据存盘(包括基础数据,人员数据),均采用文本文件ofstreamfPerson,fBase;charc;coutc;if(toupper(c)!=Y)return;/保存人员编号、姓名、岗位fPerson.open(person.txt,io
24、s: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;fBase销售人员提成tSalesPercentendl;fBase技术
25、人员小时工资tWagePerHourendl;fBaseIDtIDendl;fPerson.close();coutbufManagerSalary;/经理固定月薪fBasebufSalesManagerSalary;/销售经理固定月薪fBasebufSalesManagerPercent;/销售经理提成fBasebufSalesPercent;/销售人员提成fBasebufWagePerHour;/技术人员小时工资fBasebufID;/员工标识fBase.close();/清除内存人员数据Clear();/人员数据数据装入ifstreamfPerson;Person*p=Worker;in
26、tNo;charName20;intDuty;doubleAmount,T;fPerson.open(person.txt,ios:in);/读一条记录fPersonNoNameDuty;if(Duty=3)fPersonAmount;elseif(Duty=4)fPersonT;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)
27、;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;/连接/读下一条记录fPersonNoNameDuty;if(Duty=3)fPersonAmount;elseif(Duty=4)fPersonT;fPerson.close();coutn人员和基础数据已经装入.n;voidmain()charc;Companya;docoutn*公司人员管理系统*n;cout1增加人员n;cout2删除人员n;cout3修改人员n;cout4查询本月经营信息n;cout5基础数据设置n;cout6数据存盘n;cout7数据装入n;coutc;switch(c)case1:a.Add();break;case2:a.Delete();break;case3:a.Modify();break;case4:a.Query();break;case5:a.Set();break;case6:a.Save();break;case7:a.Load();break;while(c!=8);-