C++工资管理系统.doc_第1页
C++工资管理系统.doc_第2页
C++工资管理系统.doc_第3页
C++工资管理系统.doc_第4页
C++工资管理系统.doc_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

某大学 面向对象程序设计 课程设计报告书题目: 工资管理系统(C+) 院 系: 软件学院 专 业: 软件工程 班 级: 姓 名: 学 号: 课设时间: 2016.12.22 指导教师: 二一六年十二月面向对象程序设计课程设计报告书员工工资管理系统一、设计要求用类函数和派生类来计算某公司雇员的工资,通过多层派生和多重派生来实现对不同工资级别的工资管理。编辑实现工资管理。特别注意pay()的定义和调用方法使用运行时多态。编写程序提示用户输入employee类的共有数据,再提醒用户输入工资类型来区分工资级别不同的类的特有数据。最后通过pay()函数来计算各种数据,用Print函数输出。二、设计目的(1)、将课本上的理论知识运用于实践,通过实际的程序操作来提高自己编写程序的能力,达到理论与实践相结合的目的。(2)、查阅相关资料,自学具体课题中涉及到的新知识。(3)、根据实现的功能,划分出合理的对象类,明确对象类间的关系。为每个对象类设计正确的属性和方法,为每个方法设计合理的方法体。 (4)、编程简练,程序功能齐全,能正确运行。三、设计过程1、程序流程图employeesalesmantechnicianmanagerdevelopermanagersalesmanager2、程序原理 使用户能根据程序提示输入employee类的共有数据,再提醒用户输入工资类型来区分工资级别不同的类的特有数据。最后通过pay()函数来计算各种数据,用Print函数输出。3、算法原理通过基类中的公有函数来访问基类中的私有成员来计算各派生类的工资。 4、软件设计过程中遇到的问题以及解决办法 在这次设计程序的过程中遇到了许多问题:比如对类模板、类的多重、多层继承、析构函数、赋值构造函数等知识掌握不牢固,使得拿到题目无从下手。但最后都通过请教别人和翻课本,上网查找相关资料等途径解决了。四、程序源代码#include#include using namespace std;static int Grades=600,700,850,1000,1200,1600,2000,3000; /静态class employee protected: char *name;/姓名 int ID;/职工号 int grade;/工资级别 double salary;/月薪 double base_salary;/基本月薪 double merit_salary;/业绩工资 public: employee(char* =NULL,int=0,int=0);/构造函数 employee(); /析构函数 virtual void pay();/月薪计算函数 void show(); double getsalary()return salary; double getbase_salary()return base_salary; double getmerit_salary()return merit_salary; ;employee:employee(char*nn,int id,int gr) if(nn=NULL) name=NULL; else name=new charstrlen(nn)+1; strcpy(name,nn); ID = id; grade = gr; salary=0;/月薪 base_salary=0;/基本月薪 merit_salary=0;/业绩工资 employee:employee() if(name!=NULL) deletename; void employee:show() coutnametIDtsalaryendl; void employee:pay() int days; coutdays; base_salary = Gradesgrade*(30 - days)/30; merit_salary = base_salary/2;/普通员工业绩工资为基本工资的一半 salary = base_salary+merit_salary; class manager:virtual public employee/虚基类 protected: double prize;/固定奖金额 double factor;/业绩系数 public: manager(char* =NULL,int=0,int=0,double=0); void pay(); ; manager:manager(char*nn,int id,int gr,double pr):employee(nn,id,gr) prize = pr;/固定奖金额 factor = 0; void manager:pay() int days; coutdays; coutfactor; base_salary = Gradesgrade*(30 - days)/30; merit_salary = prize*factor*(30 - days)/30; salary = base_salary + merit_salary ; class technician:virtual public employee protected: double hours;/月工作时数 double perhour;/每小时附加酬金 double shfactor;/研究进度系数 public: technician(char* =NULL,int=0,int=0,double=0); void pay(); ; technician:technician(char*nn,int id,int gr,double phr):employee(nn,id,gr) hours = 0; perhour = phr;/每小时附加酬金 shfactor = 0; void technician:pay() int days; coutdays; coutshfactor; hours=8*(30-days); base_salary = Gradesgrade*(30 - days)/30; merit_salary = perhour*hours*shfactor*(30 - days)/30; salary= base_salary + merit_salary ; class salesman:virtual public employee protected: double amount;/销售额 double slfactor;/提成比例 public: salesman(char* =NULL,int=0,int=0,double=0); void pay(); ; salesman:salesman(char*nn,int id,int gr,double slfac):employee(nn,id,gr) amount = 0; slfactor = slfac;/提成比例 void salesman:pay() int days; coutdays; coutamount; base_salary = Gradesgrade*(30 - days)/30; merit_salary = amount*slfactor; salary = base_salary + merit_salary ; class developermanager:public manager,public technician public: developermanager(char* =NULL,int id=0,int gr=0,double pr=0, double phr=0); void pay(); ; developermanager:developermanager(char*nn,int id,int gr,double pr,double phr) :manager(nn,id,gr,pr),technician(nn,id,gr,phr),employee(nn,id,gr) void developermanager:pay() int days; coutdays; coutfactor; coutshfactor; hours=8*(30-days); base_salary = Gradesgrade*(30 - days)/30;/基本工资 merit_salary = perhour*hours*shfactor*(30 - days)/30;/技术人员奖金 merit_salary += prize*factor*(30 - days)/30;/加经理业绩工资 merit_salary /=2; salary = base_salary + merit_salary ; class salesmanager:public manager,public salesman public: salesmanager(char* =NULL,int=0,int=0,double pr=0, double slfac=0); void pay(); ; salesmanager:salesmanager(char*nn,int id,int gr,double pr,double slfac) :manager(nn,id,gr,pr),salesman(nn,id,gr,slfac),employee(nn,id,gr) void salesmanager:pay() int days; coutdays; coutfactor; coutamount; base_salary = Gradesgrade*(30 - days)/30;/基本工资 merit_salary = prize*factor*(30 - days)/30;/经理业绩工资 merit_salary /=2; merit_salary += amount*slfactor;/加销售业绩工资 salary = base_salary + merit_salary ; void main() employee eml1(Dave,10001,0),*emlp; manager mag1(John,20003,4,1000); technician tec1(Helen,30006,5,10); salesman sal1(Heidi,40009,2,0.05); developermanager dem1(Steve,50009,6,1500,12); salesmanager sam1(Ryan,60020 ,3,1000,0.05); eml1.pay(); eml1.show(); mag1.pay(); mag1.show(); tec1.pay(); tec1.show(); sal1.pay(); sal1.show(); emlp=&dem1; emlp-pay(); emlp-show(); emlp=&sam1; emlp-pay(); emlp-show(); 五、设计总结通过1周的学习,我进一步掌握了

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论