当前位置:文档之家› 职工工资管理系统设计课程设计含源代码

职工工资管理系统设计课程设计含源代码

设计题目职工工资管理系统设计xxx技术学院课程设计任务书二、对课程设计成果的要求(包括课程设计说明书、图纸、图表、实物等软硬件要求)(1)分析职工工资管理系统程序结构: 画出程序粗略的流程图和各个模块的详细流程图,每个功能模块用文字说明他们的功能(与对应流程图放在一起);(2)对你已经实现的功能(修改的、新编写的)做详细的说明, 并附上流程图及程序清单。

(3)自己对该职工工资管理系统的进一步设想;(4)对于有设想但最终未实现的功能的大致编程思路的阐述;(5)论述在设计过程中遇到的并且对你具有启发性的问题。

(6)严禁抄袭,发现雷同,双方扣分。

三、课程设计工作进度计划:周一、二:教师布置任务,讲解本课设模块。

画出主程序粗略的流程图和各个模块的详细流程图。

设计程序及调试程序。

周三、四:设计程序及调试程序。

同时着手写报告。

周五:完成设计,提交报告,接受教师考评。

四、主要参考资料(1)《面向对象程序设计》,郑莉,清华大学出版社,(2)《面向对象程序设计C++语言》,朱战立等编西安电子科技大学出版社(3)《面向对象程序设计----Visual C++》,刘斌等编, 清华大学出版社(4)《面向对象程序设计----C++语言描述》, Richard Johnsonbaugh(美)等著,蔡宇辉等译,机械工业出版社,2003目录1 概述: (5)1.1 基本功能 (5)1.2 拓展功能 (5)2 课题分析 (6)2.1 类的设计 (6)2.2类的实现 (6)3 详细设计说明 (7)3.1 程序主界面 (7)3.2 方案 (7)3.3 程序描述(输入INPUT) (9)4 课程设计总结 (12)5 软件使用说明 (12)6 附录(参考文献,原代码:) (13)6.1 参考文献: (13)6.2 原代码 (13)1概述:1.1 基本功能实现一个简单的工资管理系统。

系统的主要用来计算职工当月工资并存档。

由于公司内有5种不同类型的职工:技术人员、销售人员、文秘、技术经理和销售经理,他们的工资计算方式各不相同。

所以,此系统的基本功能是:首先,由员工输入用户信息(包括编号、姓名和职务;然后,计算某职工的当月工资(系统先从已输入的职工信息文件中获取职工的工作类型;接着调用不同的处理程序进行计算);最后,可以选择将结果(所有员工的编号、姓名、职位、工资等信息)存档。

1.2 拓展功能1.设定好5种职位各不相同的工资计算方式:技术人员的工资根据他当月工作的小时数来定,时薪35元;销售人员的工资则是根据本人当月销售额来确定,工资为销售额的5%;文秘有4000元的基本工资,奖金视为当月工作情况而定;技术经理和销售经理都有6000元的固定工资,技术经理的工作业绩可分为3个等级,PS:每级可获得1000元奖金(¥1000、¥2000、¥3000);销售经理的奖金由他所管理的销售员的销售业绩而定,总销售额的2%。

2.添加某个职工信息的查询功能:只要输入一个已经存在数据库内的雇员名字,即可查到该雇员的编号、姓名、职位和工资的信息。

3.清屏功能:为了保护雇员个人信息不外露。

4.警报功能:在查询职员工资信息的时候,会发出警报音“滴——”的一声。

5.退出确定功能退出程序时,会让用户再次确定是否真的要退出的界面。

2课题分析2.1 类的设计从用户需求中,可以发现5种类型的职员都可以分别设计为一个类。

首先,他们都属于雇员,因此可以设计一个基类employee(雇员),然后从中派生出technician(技术人员)类,salesman(销售人员)类、secretary(文秘)类、techmanager(技术经理)类和manager(销售经理)类。

根据用户需要employee类应该拥有的属性有:编号、姓名、职务、月份和工资。

Employee 类的服务可以包括input(),print(),find(),save()。

其中,input()函数用于接收用户输入的职工信息;print()函数用于输出用户输入的职工信息;find()函数用来根据职工名查找职工信息;save()函数为将职工信息写入文本。

由于各类人员的工资计算方法不同,无法在基类中统一定义,必须在派生类中分别定义。

2.2类的实现class Technician:public Employee //技术员类(公有继承雇员类){public:void input(){ Array cout<<"技术员的";Employee::input();cout<<"工作时间:";cin>>worktime;}void print(){ pay=worktime*hourpay;Employee::print();}void find(){pay=worktime*hourpay;Employee::find();}void save(){ pay=worktime*hourpay; 其他类,类似形成。

Employee::save();}protected:double worktime; //工作时间(小时)};输入用户信息,包括编号、姓名和职务从已输入的职工信息文件中获取职工的工作类型调用不同的处理程序进行查询,职员信息将结果存档开始3 详细设计说明3.1 程序主界面图表 1主菜单目录3.2 方案在明确了整个程序基本的功能目的后,接着,便是思考如何具体实现:输入用户信息,包括编号、姓名和职务 从已输入的职工信息文件中获取职工的信息调用不同的处理程序进行查询,职员信息将结果存档开始开始问题1:存入的数据放在哪里?const int n1=1,n2=1,n3=1,n4=1,n5=1; /*定义公司各类职工人数(可修改)(n1:技术员人数;n2:经理人数;n3:销售员人数;n4:销售经理人数 )*/事先设定好可修改的全局变量。

然后确定好全局对象数组。

如此便可以按照所需存入员工信息问题派生类派生类派生类派生类基类派生类问题个菜单关系?(输入职员信息菜单、目录菜单)让目录菜单作为主菜单,输入职员信息的菜单成为二级菜单。

并运用清屏的功能,及时清除输入的职员信息,作为一种安全保护。

3.3 程序描述(输入input)* 由主菜单选择进入“1”的数据输入菜单,进行数据输入(进入二级菜单后会自动清屏)。

图表2子菜单(程序中的menu 3)* 根据需要选择输入要输入的职员信息。

(只需按照中文提示,依次输入英语或数字信息)图表3子菜单中选择输入技术经理信息的一个状态* 一个职员的信息全部输入完成后,会自动清屏,回到“财务部门输入数据系统”主菜单图表 4 子菜单* 以此类推,随意输入你要输入的职员信息。

若输入全部完成,可以回到主菜单* 然后,在主菜单中选择数据查询,可以根据你填入的职工姓名,查到他的所有信息图表 5 由主菜单选择查询一操作时,反馈信息的状态* 也可选择数据备份,会自动清屏。

并让所有已输入过的职工信息,全打印在所在磁盘的一个txt文档里。

图表 6 由主菜单选择数据备份一操作后的状态* 如果想要退出系统,可以选择主菜单的退出系统,选择过后,会清屏,显示以下界面,警告用户,是否真的要推出。

图表7 选择主菜单退出系统一操作后的状态4课程设计总结通过此次面向对象程序设计的实践课程学习,本人受益匪浅。

经过一系列的编程,本人更加体会到纸上得来终觉浅,绝知此事要躬行。

实践是检验真理的唯一标准。

这两句话说的真切。

遇到的难关1.在编写销售经理的类的时候,由于思维混乱,继承乱用,以致真个程序一片混乱,运行不出,且外加几十个错误警告。

经过回顾自己先前写的流程图,本人得到了很大的顿悟。

关系捋清楚了,思路也豁然开朗了,下笔如有神。

遇到的难关2.五种职员在计算工资的时候,先前一直查询不到正确的工资数额。

在反复检查、测试的过程中,才发现那些计算公式,继承没有问题,问题出在查询的那个函数忘记将重新计算工资的公式写上。

所以一直显示的是employee的工资数,而不是各个职位员工的工资数。

遇到的难关3.在增加清屏这一功能时,本以为这很简单。

可在具体操作时,才发现,这也考验一个人思维逻辑的严谨。

曾设想,为了不泄密,将清屏这一函数放在查询函数后。

结果没想到,这导致测试时:工资信息一显示,立刻被擦掉,根本来不及看的窘境。

存在的不足1.本程序设计上还有明显的不妥,就是查询工资信息的时候,要求输入的仅仅为用户姓名。

由于还是英语输入,难免有同名同姓的状况出现,容易混乱与出错,还需改进。

存在的不足2.原本思路是将程序分为两个入口:管理员入口和职员入口。

管理员入口:需要输入通行账户和密码。

进入后,有两个功能——输入所有职工信息(编号、姓名、岗位、月份、业绩奖励等等基本信息)和数据备份。

职员入口:则面向所有员工。

进入后,只有一个功能——根据自己的名字和编号查询自己的工资等信息。

可是由于实际精力有限,时间的不足。

只能不分入口,直接将所有功能放在一个界面内——主菜单内。

这样不能很好的起到原先设想的保护功能。

实乃缺失。

总之,这不到一周的实践课,让本人的对于知识的应用能力有了显著的提升。

本人也明白了,想要真正会编程,就要课后下功夫,多“实战”。

这样的进步才更大。

5软件使用说明1.主菜单中,先输入1,按回车。

进入输入数据职员的菜单界面。

2.按文字提示信息,依次输入5种职员的各个信息。

EG:编号姓名职位101 zhao techmanager202 qian technician303 sun salesman404 li manager505 zhou secretary3.输入完毕后,输入0,按回车。

再次回到主菜单。

4.输入2,按回车。

可以输入你想查看的职工姓名,按回车,查看其信息。

5.输入3,按回车。

可以将所有职工的信息,做成文本。

6.输入0,按回车。

可以通过输入y或n选择,是否退出程序。

友情提示:1.由于语言局限,输入的信息仅限26个字母和阿拉伯数字。

2.自动清屏是出于对雇员信息的保护和界面整洁。

并非出错,请勿恐慌。

3.备份资料时,电脑发出的“滴”的警报声,只是提示用户,备份已完成。

6附录(参考文献,原代码:)6.1 参考文献:(1)《面向对象程序设计》,郑莉,清华大学出版社,(2)《面向对象程序设计C++语言》,朱战立等编西安电子科技大学出版社(3)《面向对象程序设计----Visual C++》,刘斌等编, 清华大学出版社(4)《面向对象程序设计----C++语言描述》, Richard Johnsonbaugh(美)等著,蔡宇辉等译,机械工业出版社,20036.2原代码#INCLUDE<FSTREAM>#INCLUDE<IOSTREAM>#INCLUDE<STRING>#INCLUDE<IOMANIP>#INCLUDE<STDLIB.H>USING NAMESPACE STD;//常变量(供修改用):CONST INT N1=1,N2=1,N3=1,N4=1,N5=1;/*定义公司各类职工人数(可修改)(N1:技术员人数;N2:经理人数;N3:销售员人数;N4:销售经理人数)*/CONST DOUBLE M_SALARY=6000;//经理固定月工资CONST DOUBLE HOURPAY=35;//技术员小时工资CONST DOUBLE BASICPAY=6000;//销售经理的底薪CONST DOUBLE SECRETARYPAY =4000;//文秘的底薪CONST DOUBLE S_PROPORTION=5.0/100;//销售员的工资提成比例CONST DOUBLE SM_PROPORTION=2.0/100;//销售经理的提成比例DOUBLE SOLD_AMOUNT;//声明部分:VOID MENU();//主菜单(1/2/3/0)VOID MENU3();//数据打印二级菜单(1/2/3/4/5/0)VOID DATA_INPUT();//数据输入函数DOUBLE SM_SALARY();//销售经理工资计算VOID DATA_FIND();//数据查询VOID DATA_SAVE();//数据备份(做到TXT中)VOID CLEAR();OFSTREAM OUTFILE;//打开磁盘文件流对象STRING F_NAME;//全局变量(查询用)//定义类:CLASS E MPLOYEE //雇员类(基类){PUBLIC:VOID INPUT()//数据输入函数{COUT<<"编号:";CIN>>NUM;COUT<<"其姓名:";CIN>>NAME;COUT<<"职位:";CIN>>STATUS;COUT<<"月份:";CIN>>MONTH;}VOID PRINT()//打印数据函数{COUT<<"编号\T姓名\T职位\T\T月份\T工资"<<ENDL;COUT<<NUM<<"\T"<<NAME<<"\T"<<STATUS<<"\T"<<MONTH<<"\T"<<PAY<<ENDL; }VOID FIND()//查询函数{IF(F_NAME==NAME ){PRINT();COUT<<ENDL;}}VOID SAVE()//备份数据函数{OUTFILE<<NUM<<"\T"<<NAME<<"\T"<<STATUS<<"\T"<<MONTH<<"\T"<<PAY<<ENDL; }PROTECTED:INT NUM;//职工号STRING NAME;//职工姓名STRING STATUS;//职工职位INT MONTH;//工资月份DOUBLE PAY;//职工工资};CLASS T ECHNICIAN:PUBLIC E MPLOYEE //技术员类(公有继承){PUBLIC:VOID INPUT(){COUT<<"技术员的";E MPLOYEE::INPUT();COUT<<"工作时间:";CIN>>WORKTIME;}VOID PRINT(){ PAY=WORKTIME*HOURPAY;E MPLOYEE::PRINT();}VOID FIND(){PAY=WORKTIME*HOURPAY;E MPLOYEE::FIND();}VOID SAVE(){ PAY=WORKTIME*HOURPAY;E MPLOYEE::SAVE();}PROTECTED:DOUBLE WORKTIME;//工作时间(小时)};CLASS M ANAGER:PUBLIC E MPLOYEE //技术经理类{PUBLIC:VOID INPUT(){COUT<<"技术经理的";E MPLOYEE::INPUT();COUT<<"业绩奖励(输入金额数:1000、2000或3000):"; CIN>>M_EXPAY;}VOID PRINT(){ PAY=M_SALARY+M_EXPAY;E MPLOYEE::PRINT();}VOID FIND(){ PAY=M_SALARY+M_EXPAY;E MPLOYEE::FIND();}VOID SAVE(){ PAY=M_SALARY+M_EXPAY;E MPLOYEE::SAVE();}PROTECTED:INT M_EXPAY;};CLASS S ELL_M ANAGER:PUBLIC E MPLOYEE //销售经理类{PUBLIC:VOID INPUT(){ COUT<<"销售经理的";E MPLOYEE::INPUT();}INT SM_NUMBER()//调用销售经理职工号{RETURN NUM;}STRING SM_NAME()//调用销售经理姓名{RETURN NAME;}VOID PRINT(){ PAY=BASICPAY+SOLD_AMOUNT*SM_PROPORTION;COUT<<"编号\T姓名\T职位\T\T月份\T工资"<<ENDL;COUT<<NUM<<"\T"<<NAME<<"\T"<<STATUS<<"\T\T"<<MONTH;}VOID SAVE(){PAY=BASICPAY+SOLD_AMOUNT*SM_PROPORTION;OUTFILE<<NUM<<"\T"<<NAME<<"\T"<<STATUS<<"\T\T"<<MONTH; }VOID FIND(){IF(F_NAME==NAME ){PRINT();COUT<<ENDL;}}};CLASS S ELLER:PUBLIC E MPLOYEE //销售员类{PUBLIC:S ELLER(){ SOLD_AMOUNT=0;}//构造函数,销售额初始化为0VOID INPUT(){COUT<<"销售员的";E MPLOYEE::INPUT();COUT<<"销售额:";CIN>>SOLD_AMOUNT;COUT<<"所属销售经理的编号:";CIN>>NU;}VOID PRINT(){ PAY=SOLD_AMOUNT*S_PROPORTION;COUT<<NUM<<"\T"<<NAME<<"\T"<<STATUS<<"\T"<<MONTH<<"\T"<<PAY<<"\T"<<NU<<ENDL;}INT S_NUMBER()//调用销售员所属销售经理职工号{RETURN NU;}DOUBLE AMOUNT()//调用销售员销售额{RETURN SOLD_AMOUNT;}VOID FIND(){ IF(F_NAME==NAME){COUT<<"编号\T姓名\T职位\T\T月份\T工资\T所属部门经理编号"<<ENDL; PRINT();}}VOID SAVE(){ PAY=SOLD_AMOUNT*S_PROPORTION;OUTFILE<<NUM<<"\T"<<NAME<<"\T"<<STATUS<<"\T"<<MONTH<<"\T"<<PAY<<"\T\T"<<NU<<ENDL;}PROTECTED:DOUBLE SOLD_AMOUNT;//销售额INT NU;//所属销售经理职工号};CLASS S ECRETARY:PUBLIC E MPLOYEE //文秘类{PUBLIC:VOID INPUT(){COUT<<"文秘的";E MPLOYEE::INPUT();COUT<<"附加奖励(输入本月奖金数额):";CIN>>SY_EXPAY;}VOID PRINT(){ PAY=SECRETARYPAY+SY_EXPAY;E MPLOYEE::PRINT();}VOID FIND(){PAY=SECRETARYPAY+SY_EXPAY;E MPLOYEE::FIND();}VOID SAVE(){ PAY=SECRETARYPAY+SY_EXPAY;E MPLOYEE::SAVE();}PROTECTED:INT SY_EXPAY;};//定义全局对象数组T ECHNICIAN T[N1];//技术员M ANAGER M[N2];//经理S ELLER S[N3];//销售员S ELL_M ANAGER SM[N4];//销售经理(下属若干销售员)S ECRETARY SY[N5];//文秘//主函数部分:INT MAIN(){CHAR N;MENU();FOR(INT I=0;I<1000;I++)//设定循环次数(便于各项操作的切换及方便查询){CIN>>N;SWITCH(N){CASE'1'://数据输入CLEAR();COUT<<ENDL<<"您所选操作为数据输入,请继续--"<<ENDL<<ENDL;DATA_INPUT();COUT<<ENDL;MENU();BREAK;CASE'2'://数据查询CLEAR();COUT<<ENDL<<"您所选操作为数据查询,请继续--"<<ENDL<<ENDL;COUT<<"请输入您要查询的职工姓名:";CIN>>F_NAME;COUT<<ENDL<<"--正在查询,请等待--"<<ENDL<<ENDL;COUT<<"您查询的信息如下:"<<ENDL<<ENDL;DATA_FIND();COUT<<ENDL<<ENDL;MENU();BREAK;CASE'3'://数据备份CLEAR();OUTFILE.OPEN("C++程序设计实习.TXT",IOS::OUT);//打开磁盘文件流对象COUT<<ENDL<<"您所选操作为数据备份,请继续--"<<ENDL<<ENDL;OUTFILE<<"职工基本情况一览表如下:"<<'\N'<<ENDL;DATA_SAVE();OUTFILE.CLOSE();COUT<<ENDL<<ENDL;COUT<<'\A'<<"--数据备份完成,请继续--"<<ENDL<<ENDL;MENU();BREAK;CASE'0'://退出系统CLEAR();COUT<<ENDL<<"是否真的要退出系统?"<<ENDL<<ENDL;COUT<<"是( Y )"<<""<<"否( N )";CIN>>N;IF(N=='Y'){ COUT<<'\N'<<"--请按任意键退出系统--"<<ENDL; EXIT(0); COUT<<ENDL;} ELSE MENU();BREAK;DEFAULT:COUT<<ENDL<<"--出错!请重新选择操作!"<<'\N'<<ENDL;MENU();BREAK;}}RETURN 0;}//自定义函数部分:VOID MENU()//菜单函数{COUT<<"★小型公司工资管理系统★"<<ENDL;COUT<<"┌───────────────┐"<<ENDL;COUT<<"│数据输入:1,并按回车键;│"<<ENDL;COUT<<"└───────────────┘"<<ENDL; COUT<<"│数据查询:2,并按回车键;│"<<ENDL; COUT<<"└───────────────┘"<<ENDL; COUT<<"│数据备份:3,并按回车键;│"<<ENDL; COUT<<"└───────────────┘"<<ENDL; COUT<<"│|退出系统:0,并按回车键;|│"<<ENDL; COUT<<"└───────────────┘"<<ENDL; COUT<<"请输入操作序号:";}VOID MENU2()//数据输入二级菜单函数{COUT<<"★★财务部门输入数据系统★★"<<ENDL;COUT<<"┌──────────────────┐"<<ENDL; COUT<<"│技术经理数据输入:1,并按回车键;│"<<ENDL;COUT<<"│技术员数据输入:2,并按回车键;│"<<ENDL;COUT<<"│销售员数据输入:3,并按回车键;│"<<ENDL;COUT<<"│销售经理数据输入:4,并按回车键;│"<<ENDL;COUT<<"│文秘数据输入:5,并按回车键;│"<<ENDL;COUT<<"│返回上一级:0,并按回车键;│"<<ENDL;COUT<<"└──────────────────┘"<<ENDL; COUT<<"请输入操作序号:";}VOID DATA_INPUT()//数据输入函数{CHAR P;INT I;MENU2();FOR(INT J=0;J<100;J++){CIN >> P;IF(P=='0'){CLEAR(); BREAK;}ELSE{SWITCH(P){CASE'1':CLEAR();FOR(I=0;I<N2;I++)M[I].INPUT();//经理COUT<<ENDL<<"-------------------------------------------------------"<<ENDL;CLEA R();MENU2();BREAK;CASE'2':CLEAR();FOR(I=0;I<N1;I++)T[I].INPUT();//技术人员COUT<<ENDL<<"-------------------------------------------------------"<<ENDL;CLEA R();MENU2();BREAK;CASE'3':CLEAR();FOR(I=0;I<N3;I++)S[I].INPUT();//销售员COUT<<ENDL<<"--------------------------------------------------------"<<ENDL;CL EAR();MENU2();BREAK;CASE'4':CLEAR();FOR(I=0;I<N4;I++)SM[I].INPUT();//销售经理COUT<<ENDL<<"---------------------------------------------------------"<<ENDL;C LEAR();MENU2();BREAK;CASE'5':CLEAR();FOR(I=0;I<N5;I++)SY[I].INPUT();//文秘COUT<<ENDL<<"---------------------------------------------------------"<<ENDL;C LEAR();MENU2();BREAK;}}}}DOUBLE SALARY[N4];DOUBLE SM_SALARY()//销售经理工资计算{INT I,J;DOUBLE A ;S ELL_M ANAGER B;FOR(INT K=0;K<N4;K++)SALARY[K]=0;FOR(I=0;I<N4;I++){ DOUBLE SUM=0;FOR(J=0;J<N3;J++)IF(S[J].S_NUMBER()==SM[I].SM_NUMBER()){ SUM=SUM+S[J].AMOUNT();SALARY[I]=SUM*SM_PROPORTION+BASICPAY;}}RETURN 0;}VOID DATA_FIND()//数据查询函数{FOR(INT I=0;I<N1;I++)//查询技术员数据{ T[I].FIND();}FOR(INT I=0;I<N2;I++)//查询技术经理数据{M[I].FIND();}FOR(INT I=0;I<N3;I++)//查询销售员数据S[I].FIND();FOR(INT I=0;I<N4;I++)//查询销售经理的数据IF(F_NAME==SM[I].SM_NAME()){SM[I].PRINT();SM_SALARY();COUT<<SETW(12)<<SALARY[I]<<ENDL;COUT<<ENDL;BREAK;}FOR(INT I=0;I<N5;I++)//查询文秘数据SY[I].FIND();}VOID DATA_SAVE()//数据备份函数{OUTFILE<<ENDL<<"技术员"<<ENDL<<ENDL;//技术员信息OUTFILE<<"编号\T姓名\T职位\T\T月份\T工资"<<ENDL;FOR(INT I=0;I<N1;I++)T[I].SAVE();OUTFILE<<ENDL<<ENDL<<"---------------------------------------------------------------------------"<<ENDL;OUTFILE<<ENDL<<"技术经理"<<ENDL<<ENDL;//经理信息OUTFILE<<"编号\T姓名\T职位\T\T月份\T工资"<<ENDL;FOR(INT I=0;I<N2;I++)M[I].SAVE();OUTFILE<<ENDL<<ENDL<<"----------------------------------------------------------------------------"<<ENDL;OUTFILE<<ENDL<<"销售经理"<<ENDL<<ENDL;//销售经理信息OUTFILE<<"编号\T姓名\T职位\T\T月份\T工资"<<ENDL; FOR(INT I=0;I<N4;I++){ SM[I].SAVE();OUTFILE<<SETW(12)<<SALARY[I]<<ENDL;}OUTFILE<<ENDL<<ENDL<<"----------------------------------------------------------------------------"<<ENDL<<ENDL;OUTFILE<<ENDL<<"销售员"<<ENDL<<ENDL;//销售员信息OUTFILE<<"编号\T姓名\T职位\T\T月份\T工资\T\T所属部门经理编号"<<ENDL;FOR(INT I=0;I<N3;I++)S[I].SAVE();OUTFILE<<ENDL<<ENDL<<"-----------------------------------------------------------------------------"<<'\N'<<ENDL;OUTFILE<<ENDL<<"文秘"<<ENDL<<ENDL;//文秘信息OUTFILE<<"编号\T姓名\T职位\T\T月份\T工资"<<ENDL;FOR(INT I=0;I<N5;I++)SY[I].SAVE();OUTFILE<<ENDL<<ENDL<<"----------------------------------------------------------------------------"<<ENDL;}VOID CLEAR(){ SYSTEM("CLS");}补充:小型公司职员档案(秘!)编号姓名职位101 zhao techmanager202 qian technician303 sun salesman404 li manager505 zhou secretary(注:文档可能无法思考全面,请浏览后下载,供参考。

相关主题