C++人事管理系統課程設計報告_第1頁
C++人事管理系統課程設計報告_第2頁
C++人事管理系統課程設計報告_第3頁
已閱讀5頁,還剩14頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、一、設計題目(問題)描述和要求1 題目:人事管理系統2 問題描述: 某小型公司,主要有四類人員:經理、兼職技術人員、銷售經理和兼職推銷 員。現在,需要存儲這些人員的姓名、編號、級別、當月薪水,計算月薪總額并 顯示全部信息。要求:( 1) 其中,人員編號在生成人員信息時同時生成, 每輸入一個人員信息編號順 序加 1。( 2) 程序對所有人員有提升級別的功能( 3) 月薪的計算方法是: 經理拿固定月薪, 兼職技術人員按工作小時數領取月 薪,兼職推銷員的報酬按該推銷員當月銷售額提成 , 銷售經理既拿固定月 薪也領取銷售提成。( 4) 能按姓名或者編號顯示、查找、增加、刪除和保存各類人員的信息二、系統

2、分析與模塊設計 根據問題描述和要求,系統要求能夠按姓名或者編號顯示、查找、增加、刪 除和保存各類人員的信息。確定程序至少應該具備如下功能: “查詢人員”、“增 加人員”、“刪除人員”、“數據存盤”基本模塊。系統既然具有“數據存盤”功能人員數據可以保存到磁盤文件,那么也就 意味著今后可以從磁盤文件讀出人員數據, 所以系統增加了 “人員數據裝入” 模 塊,以方便用戶使用、避免數據重復錄入。考慮到系統實現簡捷,人員數據文件 采用文本文件,人員數據文件名: Person.txt 。做為一個完整系統,除了具有增加人員,刪除人員信息模塊,還應該具有修 改人員相關信息的功能,所以本系統設計時考慮增加“修改人

3、員”模塊。考慮到根據編號查找人員信息功能在“刪除人員” 、“修改人員”等模塊都使 用,所以可以考慮設置為一個模塊。考慮到系統要求人員編號在生成人員信息時同時生成,每輸入一個人員信息編號順序加 1。這樣就要求人員編號在增加人員時自動生成 ( 增加 1)且不重復。 根據這個要求,可以考慮設置一個全局量: “當前最大編號”,每增加一個人員, 當前最大編號自動增 1,然后新增加人員使用這個編號。為了保證系統能記憶這 個編號,可以使用一個數據文件保存當前這個編號。 系統每次開始運行前從文件 讀入這個編號, 隨著人員增加, 編號自動增加, 系統每次運行結束時將這個編號 寫入文件。本系統將初值 ( 沒有一個

4、用戶時 )設置為 0。考慮到人員的許多固定信息如:經理、銷售經理的固定月薪,銷售經理、銷 售人員提成, 技術人員小時工資等都是一些不需要每個人員都要輸入的信息, 所 以可以將這些信息都保存在一個數據文件中, 本系統為了方便起見, 將這些信息 與“最大編號”全部保存在一個文件中,并使用“基礎數據設置”模塊進行設置 和管理。基礎數據文件也采用文本文件,基礎數據文件名: Base.txt 。本系統還提供“查詢本月經營信息”幫助計算銷售總額,工資總額,并按照 公式計算本月盈虧。綜合考慮系統具有下面 8 項功能模塊:增加人員,刪除人員,修改人員,查 詢本月經營信息,基礎數據設置,數據存盤,數據裝入。系統

5、使用的數據文件格式如下:Base.txt: (格式:項目 數據 ) 經理固定月薪 3000 銷售經理固定月薪 1000 銷售經理提成 1 銷售人員提成 2 技術人員小時工資 20ID 6Person.txt:(格式:編號,姓名,人員類別,其它數據,銷售員銷售額,技術人員工作小時)2 wang 31000003 liu 14 wu 4 1005 huang 26 tao 3150000注:人員類型編號 1經理; 2銷售經理; 3銷售員; 4技術人員三、系統設計1. 系統總體框架使用面向對象的程序設計思想進行分析,整個系統涉及兩大類信息和操作,公司,人員。所以系統主要涉及兩個大類:公司類 Comp

6、any人員類Person。系統的總體框架就是公司類,人員類的定義;主函數中定義一個公司對象,循環顯 示主菜單并根據用戶選擇調用公司類的相應方法 (成員函數)。公司類Company考慮系統操作的人員信息的數量具有不確定性,所以考慮 使用鏈表保存、處理人員信息。公司類包含:所有人員信息的一個不帶頭結點的 鏈表(作為數據成員)及可以對人員信息進行增,刪,改,查詢經營信息,基礎 數據設置,數據存盤,數據裝入等操作的相關模塊 (Add,Delete,Modify,Query,Set,Save,Load)作為成員函數。人員類Person :所有人員都具有的公共信息及操作可以使用人員類進行描 述。由于系統具

7、有4類人員且4類人員數據,操作有所不同,如銷售員包含銷售 額,而技術人員包含工作小時數且計算工資的方法不同,所以應當為4類人員創建相應的Person類的派生類。(3)為了使公司類可以方便處理人員信息,可以考慮將公司類確定為人員類的友 元類或者人員類提供公共的方法以便公司類進行操作。為了公司類可以用共同方法操作人員類,可以將人員類的方法確定為虛函數。2. 類的層次圖Person No,Name,Duty,Earni ng, next,Perso n( ),CalcSalary(),Output() Ma nager(), Amou nt,Amou nt, t,CalcSalary(), Sale

8、s(),GetAmou nt(), SalesMa nager(),Tech nicia n(),Output()SetAmou nt(),SetAmou nt(),GetT(),SetT(),CalcSalary(), CalcSalary(), CalcSalary(),Output() Output() Output()Tech ni cia n其中:(1) Person類的No-人員編號,Name人員姓名,Duty-人員類別,Earning-工 資,next-指向下一個人員的指針;Person類的CalcSalary() ,Output()定義為 純虛函數分別表示要計算人員工資和輸出人

9、員信息,由于定義純虛函數,所以Person是抽象類,具體計算工資,輸出人員信息由派生類完成。(2) 各個派生的類,包含本類對象特有的數據,Sales:Amount-銷售員銷售額,SalesManager:Amount-銷售經理的總銷售額(系統統計各個銷售員銷售額得到 銷售經理的總銷售額),Technician:t-技術人員工作小時數。Compa nyPerson *Worker,Clear(),Compa ny(),Compa ny(),Add(),Delete(),Modify(),Query(),Set(),Save(),Load()其中:(1) Worker就是人員鏈表。(2) Clea

10、r()用于清除人員鏈表所有結點。(3) Add(),Delete(),Modify(),Query(),Set(),Save(),Load()分別表示系統各個功能模塊:增加人員,刪除人員,修改人員,查詢本月經營信息,基礎數據設置,數據存盤,數據裝入。3. 系統關鍵算法流程圖(1)主函數流程開始創建公司對象顯示菜單 接受輸入根據輸入執行公司操作 Compa ny:Add() Compa ny:Delete()開始I輸入員工ID查找要刪除結點匚、.結點存在?二q F片鏈表刪除員工結點提示未找到1結束 Compa ny:Modify(5) Compa ny:Query()遍歷統計銷售額遍歷統計工資總

11、額計算盈虧打印本月經營信息結束(6)Compa ny:Save()(7) Compa ny:Load()四、源程序清單參見附錄五、系統測試(列出各功能具體的輸入數據及對應的輸出結果,說明其是否符合設計要 求)六、小結(設計過程心得體會)附錄:/*本程序有關的兩個數據文件:base.txt-基礎數據文件(必須存在,且按規定格式保存)person .txt人員信息文件(可選)*/ #include <iostream.h>#include <fstream.h>#include <ctype.h>#include <string.h> /全局數據,對

12、象double ManagerSalary;/經理固定月薪double SalesManagerSalary; /銷售經理固定月薪double SalesManagerPercent; 銷/ 售經理提成 double SalesPercent;/銷售人員提成 class Person /員工類double WagePerHour;int ID;/技術人員小時工資/員工標識(要保證唯一 )protected:int No; /編號char Name20; /姓名int Duty;/崗位double Earning; /收入Person *next;public:Person(char ID,ch

13、ar *Name,int Duty)this->Duty=Duty;strcpy(this->Name,Name);this->No=ID;virtual void CalcSalary()=0;virtual void Output()=0;friend class Company;class Manager:public Person /經理類public:Manager(char ID,char *Name,int Duty):Person(ID,Name,Duty) void CalcSalary()Earning=ManagerSalary;void Output(

14、)CalcSalary(); cout<<No<<"t"<<Name<<"t 經理 t"<<Earning<<endl;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()Ear

15、ning=SalesManagerSalary+Amount*SalesManagerPercent/100;void Output()CalcSalary(); cout<<No<<"t"<<Name<<"t 銷售經理 t"<<Earning<<endl;class Technician:public Person /技術員類private:double t;public:Technician(char ID,char *Name,int Duty,double T):Person

16、(ID,Name,Duty) this->t=T;double GetT()return t;void SetT(double T)this->t=T;void CalcSalary()Earning=WagePerHour*t;void Output() CalcSalary(); cout<<No<<"t"<<Name<<"t 技術員 t"<<t<<"t"<<Earning<<endl;class Sales:public

17、Person / 銷售員類private:double Amount;public:Sales(char ID,char *Name,int Duty,double Amount):Person(ID,Name,Duty) this->Amount=Amount;double GetAmount()return Amount;void SetAmount(double Amount) this->Amount=Amount;void CalcSalary() Earning=SalesPercent/100*Amount;void Output()CalcSalary(); cou

18、t<<No<<"t"<<Name<<"t 銷售員 t"<<Amount<<"t"<<Earning<<endl;class Company /公司類private:Person *Worker; /員工表void Clear(); /清除內存中數據 public:Company()Worker=0;Load();Company()Person *p;p=Worker;while(p) p=p->next; delete Worker;

19、 Worker=p;Worker=0;void Add();/增加人員void Delete(); /刪除人員void Modify(); /修改人員void Query(); /查詢人員void Set();/基礎數據設置void Save();/數據存盤 (包括基礎數據,人員數據 )void Load();/數據裝入 (包括基礎數據,人員數據 );void Company:Clear() /清除內存中人員數據 (內部使用 ) Person* p=Worker;while(p)Worker=p->next;delete p; p=Worker;void Company:Add()Per

20、son *p; /新結點指針int Duty;char Name20;double Amount,T;cout<<"n* 新增員工 *n"/輸入員工信息ID+;cin>>Duty;coutvv"輸入崗位(1-經理2-銷售經理3-銷售員4-技術員):" cout«"輸入姓名:"cin>>Name;if(Duty=3)cout«"本月銷售額:"cin>>Amount;else if(Duty=4)coutvv"本月工作小時數(0-168):&

21、quot;cin>>T;/創建新員工結點switch(Duty)case 1:p=new Manager(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

22、) /查找尾結點p2=p2->next;p2->next=p; /連接else /若不存在結點 (表空 )Worker=p; /連接void Company:Delete() /刪除人員int No; cout<<"n* 刪除員工 *n" cout<<"ID:" cin>>No;/查找要刪除的結點Person *p1,*p2; p1=Worker; while(p1) if(p1->No=No) break;else p2=p1; p1=p1->next;/刪除結點 if(p1!=NULL)/

23、若找到結點,則刪除 if(p1=Worker) /若要刪除的結點是第一個結點 Worker=p1->next; delete p1;else / 若要刪除的結點是后續結點 p2->next=p1->next; delete p1; coutvv"找到并刪除n"else /未找到結點 cout«"未找到!n"void Company:Modify()int No,Duty;char Name20;double Amount,T;cout<<"n* 修改員工 *n" cout<<&quo

24、t;ID:" cin>>No;/查找要修改的結點Person *p1,*p2; p1=Worker; while(p1)if(p1->No=No)break;elsep2=p1; p1=p1->next;/修改結點 if(p1!=NULL)/ 若找到結點 cin>>Duty;p1->Output();coutvv"調整崗位(1-經理2-銷售經理3-銷售員4-技術員):" if(p1->Duty!=Duty)/若崗位發生變動 /修改其它數據cout«"輸入姓名:"cin>>Na

25、me; if(Duty=3)cout«"本月銷售額:"cin>>Amount;else if(Duty=4)coutvv"本月工作小時數(0-168):" cin>>T;/創建新員工結點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,A

26、mount); break;case 4:p3=new Technician(p1->No,Name,Duty,T); break;/員工結點替換到鏈表 p3->next=p1->next;if(p1=Worker) /若要替換的結點是第一個結點 Worker=p3;else /若要刪除的結點是后續結點p2->next=p3;/刪除原來的員工結點delete p1;else / 若崗位沒有變動coutvv"輸入姓名:";cin>>p1->Name;if(Duty=3)cout«"本月銷售額:"cin&#

27、187;Amount; (Sales *)p1)->SetAmount(Amount);else if(Duty=4)cout«"本月工作小時數(0-168):"cin»T; (Technician *)p1)->SetT(T);cout«"修改成功!n"else /未找到結點cout«"未找到!n"void Company:Query()cout<<"n* 查詢人員本月銷售信息 *n"double sum=0; /銷售額總和Person *p=Wor

28、ker;while(p)if(p->Duty=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«"本月盈利:"v<sum*0.20-sum2v<endl;coutvv"(按照20%利潤計算)n"

29、;void Company:Set()cout<<"n* 設置基礎數據 *n"cout«"經理固定月薪"<<ManagerSalaryvv"元:" cin>>ManagerSalary;cout«"銷售經理固定月薪"«SalesManagerSalaryvv'元:" cin>>SalesManagerSalary;coutvv"銷售經理提成"vvSalesManagerPercent<<%

30、 :" cin>>SalesManagerPercent;coutvv"銷售人員提成"vvSalesPercent<<"%:" cin>>SalesPercent;coutvv"技術人員小時工資"v<WagePerHourvv"(元/小時):" cin>>WagePerHour;coutvv"員工標識>="vv|Dvv":"cin>>ID;void Company:Save() /數據存盤 (包

31、括基礎數據,人員數據 ),均采用文本文件ofstream fPerson,fBase;char c;coutvv"n 保存人員和基礎數據 ,是否繼續 ?Y/N:"cin>>c;if(toupper(c)!='Y')return;/保存人員編號、姓名、崗位fPerson.open("person.txt",ios:out);Person *p=Worker;while(p)fPersonvvp->Novv"t"vvp->Namevv"t"vvp->Dutyvv"

32、t"if(p->Duty=3) fPerson<<(Sales*)p)->GetAmount()<<"t"else if(p->Duty=4)fPerson<<(Technician *)p)->GetT()<<"t" fPerson<<endl;p=p->next;fPerson.close();/保存基礎數據fBase.open("base.txt",ios:out);fBase«"經理固定月薪 t"v

33、<ManagerSalaryvvendl;fBase«"銷售經理固定月薪 t"<<SalesManagerSalaryvvendl; fBase«"銷售經理提成 t"<<SalesManagerPercent<<endl; fBasevv"銷售人員提成 t"<<SalesPercent<<endl;fBasevv"技術人員小時工資 t"v<WagePerHourv<endl; fBasevv"IDt"

34、;vvIDvvendl;fPerson.close();coutvv"n 保存人員和基礎數據已經完成 .n" void Company:Load() /數據裝入 (包括基礎數據,人員數據 ) /基礎數據裝入ifstream fBase;char buf80; /buf 用于保存數據文件中的注釋字符串fBase.open("base.txt",ios:in);fBase>>buf>>ManagerSalary;/經理固定月薪fBase>>buf>>SalesManagerSalary; /銷售經理固定月薪 f

35、Base>>buf>>SalesManagerPercent; /銷/ 售經理提成/銷售人員提成 /技術人員小時工資 /員工標識fBase>>buf>>SalesPercent; fBase>>buf>>WagePerHour; fBase>>buf>>ID;fBase.close();/清除內存人員數據Clear();/人員數據數據裝入ifstream fPerson;Person *p=Worker;int No; char Name20; int Duty;double Amount,T;fPerson.open("person.txt",ios:in);/讀一條記錄 fPerson>>No>>Name>>Duty; if(Duty=3)fPerson>>Amount;else if(Du

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論