1、员工管理系统:1)问题描述每个员工的信息包括:编号、姓名、性别、出生年月、学历、职务、电话、住址等。系统能够完成员工信息的查询、更新、插入、删除、排序等功能。2)基本要求(1) 排序:按不同关键字,对所有员工的信息进行排序。(2) 查询:按特定条件查找员工。(3) 更新:按编号对某个员工的某项信息进行修改。(4) 插入:加入新员工的信息。(5) 删除:按编号删除已离职的员工的信息。四、参考文献1王红梅数据结构清华大学出版社2王红梅数据结构学习辅导与实验指导清华大学出版社3严蔚敏,吴伟民数据结构(C语言版)清华大学出版社五.主要内容:(一)需求分析(1)。系统分析:本系统为员工管理系统,要求对员
2、工的各项信息进行操作,其中包括新员工信息的录入,录入后对员工信息的查询,对目前所有员工信息的浏览,查看所有员工信息后对其进行修改,删除目前某个员工的信息。通过以上所有要求我得出了如下结论:首先对一个系统管理应该有个主界面,所以我先设定一个主菜单,其中包括了如下几项:1,员工信息输入。2,员工信息修改。3,员工信息删除。4,员工信息查找。5,退出。这样就需要编写一个主菜单的方法MAIN()方法来实现,第二项是员工信息输入,这项重点内容是要对输入进去的信息进行储存,包括员工的编号,姓名,性别,生日,电话,学历,职务,地址等。所以我引用了以个来完成这个操作,同时定义以个插入方法ADD()来实现数据的
3、录入。接下来是员工信息修改,编写MODIFY()方法。首先要对其进行查询,如果没有其员工编号,则报错,如果有则显示其对应编号的员工信息,同时显示对员工各项的修改项目,修改成功后返回。第四项,员工信息删除,DELE()方法,首先也先是查询,并输出目前所有员工信息,输入要删除的员工编号,删除员工信息,返回主界面。第五项,员工信息查找,FIND()方法,输入员工的编号,找到匹配的员工信息,若有,则返回本条信息,若没有则报错。通过以上分析,我确定了本系统应包含5个主要方法分别是:主菜单调用方法MAIN()方法,员工输入ADD()方法,员工信息修改MODIFY()方法,员工信息删除DELE方法和员工信息
4、查找FIND()方法。并根据其上的方法引用String.h和Fstream等来实现其操作。(2)系统流程图(二).概要设计: 本系统从总体上分一共划分为5个模块,分别menu(),add(),modify(),find(),dele()等。1.menu()主菜单。2.add()函数实现对员工基本信息的添加:void add() while(1) /控制信息添加多次的循环 for(int i=0;i.modify()函数实现对员工信息的修改:if(NUM=0) /判断员工数是否为0,即是否存在员工记录,若无记录,则退出函数 for(int i1=0;i1.find()函数实现按编号对员工的查找:
5、void find() if(NUM=0) /判断员工数是否为0,即是否存在员工记录,若无记录,则退出函数 int found=0; /用于检测是否找到该编号员工5. dele()函数实现对已离职员工信息的删除:void dele() (三).详细设计:定义一个Person封装类,每个成员都是该封装类的对象。该封装类中包含员工编号,姓名,性别,出生日期,电话、工资,学历,职务,地址等成员变量。详细代码如下:#include stringwindows.husing namespace std;int NUM=0;class Personpublic: Person() void setPers
6、on(char *num1,char *name1,char *sex1,char *birth1,char *tel1,char *degree1,char *position1,char *address1); friend void add(); friend void modify(); friend void dele(); friend void find();private: char num15; char name15; char sex5; char birth15; char tel15; char degree15; char position15; char addr
7、ess15;Person Per200;void Person:setPerson(char *num1,char *name1,char *sex1,char *birth1,char *tel1,char *degree1,char *position1,char *address1) strcpy(num,num1); strcpy(name,name1); strcpy(sex,sex1); strcpy(birth,birth1); strcpy(tel,tel1); strcpy(degree,degree1); strcpy(position,position1); strcpy
8、(address,address1);/主菜单void menu() coutnnendl; couttt*tt tt员工管理系统tt* - *tt* tt1. 员工信息输入 tt*tt* tt2. 员工信息修改 tt*tt* tt3. 员工信息删除 tt*tt* tt4. 员工信息查找 tt*tt* tt0. 退出 ttt*nnt请选择(04):;/1. 员工信息输入 char num15; system(cls); coutnumnamesexbirthteldegreepositionaddress; PerNUM.setPerson(num,name,sex,birth,tel,deg
9、ree,position,address);nntt添加数据成功!n saveCtrl=0; NUM+; return;/2. 员工信息修改void modify() if(NUM=0)nnnnnnttt没有任何员工记录。nnnttt即将返回主菜单 Sleep(2000); return; i1+)Peri1.numtPeri1.namePeri1.sexPeri1.birthPeri1.telPeri1.degreePeri1.positionPeri1.addressnum; int choice; if( strcmp(Peri.num,num)=0 ) do system( cout编
10、号t姓名t性别t生日t电话t学历t职务t地址Peri.numPeri.namePeri.sexPeri.birthPeri.telPeri.degreePeri.positionPeri.addresschoice; if(choice9) continue; switch(choice) case 1: coutPeri.num; break; case 2:请输入新的员工姓名:Peri.name; case 3:请输入新的员工性别:Peri.sex; case 4:请输入新的员工生日:Peri.birth; case 5:请输入新的员工电话:Peri.tel; case 6:请输入新的员工
11、学历:Peri.degree; case 7:请输入新的员工职务:Peri.position; case 8:请输入新的员工地址:Peri.address; case 9: return; while(choice9);/3.删除员工信息 if(Peri1.num!=NULL) cout Person temp;请输入要删除的员工的编号 if( strcmp(Peri.num,num)=0 ) temp=Peri; for(int j=i;jNUM-1;j+) Perj=Perj+1; NUM-; break; nnnt删除成功!pause/4. 员工信息查找编号t姓名t性别t生日t电话t工资
12、t学历t职务t地址请输入员工编号: system(nnnt查询结果 found=1; if(found=0) system(nnnnnnttt未找到编号为:num的该员工!nnttt即将返回主菜单! Sleep(2500);int main() int run=1; while(run) menu(); if(choice5) continue; switch(choice) case 1: add(); break; case 2: modify(); case 3: dele(); case 4: find(); default:run=0;nnnnnntt谢谢使用员工管理系统,再见! Sleep(1000); return 0;六调试与测试:调试方法:在C+程序想调试的地方按F9,然后按F5开始调试。测试结果与预想的正确。测试过程中遇到的问题:输入的排序二叉树的输入顺序不对,导致输出结果与预计的不想符。七实验界面截图:(1)管理界面(2)输入界面(3)修改信息界面(4)查询信息界面(5)删除信息界面
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1