文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C++分步实现职工管理系统详解

2022-11-13 18:50

关注

1.职工管理系统的需求

本教程主要利用C++实现一个职工管理系统

公司职工分类:普通员工,经理,老板,显示信息时,需要显示职工的编号,职工姓名,职工岗位,以及职责。

普通员工的职责:完成经理交给的任务。

经理职责:完成老板交给的任务,并下发任务给员工。

老板职责:管理公司所有事物。

程序功能
退出管理程序退出当前管理系统
增加职工信息实现批量添加职工功能,将信息录入到文件中,职工信息为:职工编号,姓名,部门编号
显示职工信息显示公司内部所有职工信息
删除离职职工按照编号删除指定的职工
修改职工信息按照职工的编号或者职工的姓名查找相关的人员信息
按照编号排序按照职工编号,进行排序,排序规则由用户指定
清空所有文档清空文件中记录的所有职工信息

2.功能实现

2.1创建管理类

class Worker_Manger
{
public:
	Worker_Manger();
	 //展示菜单
	void Dispaly() ;
	 //退出系统
	 void ExitSystem();
	 //记录职工的人数
	 int M_EmpNum=0;
	 //职工数组指针
	 Worker ** M_EmpArray=0;
	 //添加职工
	 void Add_Emp();
	 //判断是否编号重复,姓名可能相同
	 bool If_Id_Repeat(int id);
	 //保存文件
	 void Save();
	 //判断文件是否为空
	 bool M_FileEmpty=0;
	 //统计文件中的人数
	 int Get_EmpNum();
	 //初始化员工
	 void init_Emp();
	 //显示职工
	 void Show_Emp();
	 //删除职工
	 void Delete_Emp();
	 //判断是否存在要查找的职工
	 int IsExit_Id(int id);//Id查找方式
	 int IsExit_Name(string name);//Name查找方式
	 string IsExit_Id_Name_choice(int cho);
	 //查找联系人
	 void Find_Emp_Name();
	 void Find_Emp_Id();
	 void Find_Emp();
	 //修改职工信息
	 void Modify();
     //编号排序
	 void Sort_Emp();
	 //清空操作
	 void Clean_File();
	 //析构函数
	~Worker_Manger();
};

2.2退出功能

void Worker_Manger::ExitSystem()
{
	cout << "欢迎下次使用" << endl;
	system("pause");
	exit(0);
}

2.3增加联系人信息

oid Worker_Manger::Add_Emp()
{
cout << "请输入添加的职工数量:" << endl;
int addnum = 0;//保存用户的输入数量
cin >> addnum;
if (addnum > 0)
{
	int newSize = this->M_EmpNum + addnum;//新空间人数=原来的人数+新增加人数
	//开辟新空间
	Worker ** newspace = new Worker * [newSize+4];
	//拷贝原来空间的数据
	if (this->M_EmpArray != NULL)
	{
		for (int i = 0; i < this->M_EmpNum;i++)
		{
			newspace[i] = this->M_EmpArray[i];
		}
	}
	//添加新数据
	for (int i = 0; i < addnum; i++)
	{
		int id;//职工编号
		string name;//职工的姓名
		int dSelect;//部门选择
		cout << "请输入第" << i + 1 << "个职工编号:" << endl;
		cin >>id;
		//If_Id_Repeat(id);
		while (If_Id_Repeat(id))
		{
			int cho = IsExit_Id(id);//Id查找方式
			cout << "通讯录已经有相同的编号,请重新输入" << endl;
			this->M_EmpArray[cho]->Showinformation();

			cin >> id;
		}
		cout << "请输入第" << i + 1 << "个职工姓名:" << endl;
		cin >> name;
		cout << "请选择该职工的岗位:" << endl;
		cout << "1.职员" << endl;
		cout << "2.经理" << endl;
		cout << "3.总裁" << endl;
		cin >> dSelect;
		Worker* worker = NULL;
		switch (dSelect)
		{
		case 1:
			worker = new Employee(id, name, 1);
			break;
		case 2:
			worker = new Manager(id, name, 2);
			break;
		case 3:
			worker = new Boss(id, name, 3);
			break;
		default:
			break;
		}
		//将创建职工职责,保存到数组中
		newspace[this->M_EmpNum + i] = worker;
	}
	//释放空间
	delete[] this->M_EmpArray;
	//更改新空间的指向
	this->M_EmpArray = newspace;
	//更新新空间的人数
	this->M_EmpNum = newSize;
	//更新职工不为空的情况标志
	this->M_FileEmpty = false;
	//提示添加成功
	cout << "成功添加" << addnum << "名新职工" << endl;
	//保存数据
	this->Save();
}
else
{
	cout << "输入有误" << endl;
}
system("pause");
system("cls");
}

2.4显示职工信息

void Worker_Manger::Show_Emp()
{
	//判断文件是否为空
	if (this->M_FileEmpty)
	{
		cout << "文件不存在或文件为空!" << endl;
	}
	else
	{
		for (int i = 0; i < M_EmpNum; i++)
		{
			//利用多态
			this->M_EmpArray[i]->Showinformation();
		}
	}
	//按任意键清屏
	system("pause");
	system("cls");
	//Name查找方式
int Worker_Manger::IsExit_Name(string name)
{
	int index = -1;
	for (int i = 0; i < this->M_EmpNum; i++)
	{
		if (this->M_EmpArray[i]->M_name == name)
		{
			//找到
			index = i;
			break;
		}
	}
	return index;
}
//Id查找方式
int Worker_Manger::IsExit_Id(int id)
{
	int index = -1;
	for (int i = 0; i < this->M_EmpNum; i++)
	{
		if (this->M_EmpArray[i]->M_id == id)
		{
		 //找到
			index = i;
			break;
		}
	}
	return index;
}
}

2.5删除离职职工

void Worker_Manger::Delete_Emp()
{
	if (this->M_FileEmpty)
	{
		cout << "文件不存在或者为空" << endl;
	}
	else 
	{
		int choose=0;
		cout << "请选择通过方式几查找要删除的联系人" << endl;
		cout << "1.通过姓名查找要删除的联系人" << endl;
		cout << "2.通过编号查找要删除的联系人" << endl;
		cin >> choose;
		switch (choose)
		{
		case 1: 
		{
			cout << "请输入要删除职工的姓名" << endl;
			string name;
			cin >> name;
			int index = this->IsExit_Name(name);
			if (index != -1)
			{
				string ch = IsExit_Id_Name_choice(index);
				if (ch == "是")
				{
					for (int i = index; i < this->M_EmpNum - 1; i++)
					{
						this->M_EmpArray[i] = this->M_EmpArray[i + 1];
					}
					this->M_EmpNum--;
					//数据同步更新文件当中
					this->Save();
					cout << "删除成功!" << endl;
				}
				else
				{
					cout << "取消成功" << endl;
					break;
				}
			}
			else
			{
				cout << "未找到此人,删除失败!" << endl;
				break;
			}
		}
		case 2:
		{
			cout << "请输入要删除职工的编号" << endl;
			int id=0;
			cin >>id;
			int index=this->IsExit_Id(id);
			if (index != -1)
			{
					string ch= IsExit_Id_Name_choice(index);
					if (ch == "是")
					{
						for (int i = index; i < this->M_EmpNum - 1; i++)
						{
							this->M_EmpArray[i] = this->M_EmpArray[i + 1];
						}
					
						this->M_EmpNum--;
						//数据同步更新文件当中
						this->Save();
						cout << "删除成功!" << endl;
					}
					else
					{
						break;
					}
			}
			else 
			{
				cout << "未找到此人,删除失败!" << endl;
				break;
			}
		}
		}
	}
	//按照任意键返回
	system("pause");
	system("cls");
}

2.6修改职工信息

void Worker_Manger::Modify()
{
	if (this->M_FileEmpty)
	{
		cout << "文件不存在或记录为空" << endl;
    }
	else
	{
		int choose = 0;
		cout << "请选择对应方式来查找要修改的联系人" << endl;
		cout << "1.通过姓名查找要修改的联系人" << endl;
		cout << "2.通过编号查找要修改的联系人" << endl;
		cin >> choose;
		switch (choose)
		{
		case 1:
		{
			cout << "请输入修改的职工的姓名:" << endl;
			string m_name = " ";
			cin >> m_name;
			int ret1 = this->IsExit_Name(m_name);
			if (ret1 != -1)
			{
				string str1 = IsExit_Id_Name_choice(ret1);
				if (str1 == "是")
				{
					//查找到编号的职工
					delete this->M_EmpArray[ret1];
					int newId = 0;
					string newName = " ";
					int dSelect = 0;
					cout << "输入新的职工编号" << endl;
					cin >> newId;
					If_Id_Repeat(newId);
					while (If_Id_Repeat(newId))
					{
						int cho= IsExit_Id(newId);//Id查找方式
						cout << "通讯录已经有相同的编号,请重新输入" << endl;
						this->M_EmpArray[cho]->Showinformation();
						//cout << "职工编号:" << this->M_EmpArray[cho]->M_id
						//	<< "\t职工姓名:" << this->M_EmpArray[cho]->M_name
						//	<< "\t岗位名称:" << this->M_EmpArray[cho]->GetDeptname()
						//	<< "\t岗位职责:" << this->M_EmpArray[cho]->GetDeptduty()
						//	<< endl;
						cin >> newId;
					}
					cout << "输入新的姓名" << endl;
					cin >> newName;
					cout << "请输入新的岗位" << endl;
					cout << "1.职员" << endl;
					cout << "2.经理" << endl;
					cout << "3.总裁" << endl;
					cin >> dSelect;
					Worker* worker = NULL;
					switch (dSelect)
					{
					case 1:
						worker = new Employee(newId, newName, 1);
						break;
					case 2:
						worker = new Manager(newId, newName, 2);
						break;
					case 3:
						worker = new Boss(newId, newName, 3);
						break;
					default:
						break;
					}
					this->M_EmpArray[ret1] = worker;
					cout << "更改信息成功" << endl;
					//保存到文件
					this->Save();
				}
				else if(str1 == "否")
				{
					cout << "取消成功!" << endl;
				}
			}
			else
			{
				cout << "修改失败,查无此人!" << endl;
			}
			break;
		}
		case 2:
		{
			cout << "请输入修改的职工的编号:" << endl;
			int id;
			cin >> id;
			int ret2 = this->IsExit_Id(id);
			if (ret2 != -1)
			{
				string str2 = IsExit_Id_Name_choice(ret2);
				//查找到编号的职工
				if (str2 == "是")
				{
					delete this->M_EmpArray[ret2];
					int newId = 0;
					string newName = " ";
					int dSelect = 0;
					cout << "输入新的职工编号" << endl;
					cin >> newId;
					If_Id_Repeat(newId);
					while (If_Id_Repeat(newId))
					{
						int cho = IsExit_Id(newId);//Id查找方式
						cout << "通讯录已经有相同的编号,请重新输入" << endl;
						this->M_EmpArray[cho]->Showinformation();
						//cout << "职工编号:" << this->M_EmpArray[cho]->M_id
						//	<< "\t职工姓名:" << this->M_EmpArray[cho]->M_name
						//	<< "\t岗位名称:" << this->M_EmpArray[cho]->GetDeptname()
						//	<< "\t岗位职责:" << this->M_EmpArray[cho]->GetDeptduty()
						//	<< endl;
						cin >> newId;
					}
					cout << "输入新的姓名" << endl;
					cin >> newName;
					cout << "请输入新的岗位" << endl;
					cout << "1.职员" << endl;
					cout << "2.经理" << endl;
					cout << "3.总裁" << endl;
					cin >> dSelect;
					Worker* worker = NULL;
					switch (dSelect)
					{
					case 1:
						worker = new Employee(newId, newName, 1);
						break;
					case 2:
						worker = new Manager(newId, newName, 2);
						break;
					case 3:
						worker = new Boss(newId, newName, 3);
						break;
					default:
						break;
					}
					this->M_EmpArray[ret2] = worker;
					cout << "更改信息成功" << endl;
					//保存到文件
					this->Save();
				}
				else if (str2 == "否")
				{
					cout << "取消成功!" << endl;
				}
			}
			else
			{
				cout << "修改失败,查无此人!" << endl;
			}
			break;
		}
		}
		system("pause");
		system("cls");
	}
}

2.7查找职工信息

void Worker_Manger::Find_Emp()
{
	cout << "请选择查找方式" << endl;
	cout << "1.通过姓名查找联系人" << endl;
	cout << "2.通过编号查找联系人" << endl;
	int choose = 0;
	cin >> choose;
	switch (choose)
	{
	case 1:Find_Emp_Name();
		break;
	case 2:Find_Emp_Id();
		break;
	default:
		break;
	}
}

2.8按照编号排序

void Worker_Manger::Sort_Emp()
{
	if (this->M_FileEmpty)
	{
		cout << "文件不存在或记录为空" << endl;
		system("pause");
		system("cls");
	}
	cout << "选择排序的方式" << endl;
	cout << "1.按照编号升序排列" << endl;
	cout << "2.按照编号进行降序排列" << endl;
	int choose = 0;
	cin >> choose;
	switch (choose)
	{
	case 1:
	{
		for (int i = 0; i < this->M_EmpNum; i++)
		{
			int MIN=i;
			for (int j = i+1; j < this->M_EmpNum; j++)
			{
				if (this->M_EmpArray[MIN]->M_id>this->M_EmpArray[j]->M_id)
				{
					MIN = j;
				}
			}
			if (i != MIN)
			{
				Worker* temp = M_EmpArray[i];
				M_EmpArray[i] = M_EmpArray[MIN];
				M_EmpArray[MIN] = temp;
			}
		}
		this->Save();
		this->Show_Emp();
		break;
	}
	case 2:
	{
		for (int i = 0; i < this->M_EmpNum; i++)
		{
			int MAX = i;
			for (int j = i + 1; j <this->M_EmpNum; j++)
			{
				if (this->M_EmpArray[MAX]->M_id < this->M_EmpArray[j]->M_id)
				{
					MAX = j;
				}
			}
			if (i != MAX)
			{
				Worker* temp = M_EmpArray[i];
				M_EmpArray[i] = M_EmpArray[MAX];
				M_EmpArray[MAX] = temp;
			}
		}
		this->Save();
		this->Show_Emp();
		break;
	}
	default:
		break;
	}
}

2.9清空所有文档

void Worker_Manger::Clean_File()
{
	cout << "确定清空?" << endl;
	cout << "1.确定清空" << endl;
	cout << "2.取消清空" << endl;
	int select = 0;
	cin >> select;
	if (select == 1)
	{
		ofstream ofs(FILENAME, ios::trunc);//删除文件后再重新创建
		ofs.close();
		if (this->M_EmpArray != NULL)
		{
			for (int i = 0; i < this->M_EmpNum; i++)
			{
				delete this->M_EmpArray[i];
				this->M_EmpArray[i] = NULL;
		    }
			delete[]this->M_EmpArray;
			this->M_EmpNum = 0;
			this->M_EmpArray = NULL;
			this->M_FileEmpty = true;
		}
		cout << "清空成功" << endl;
	}
	system("pause");
	system("cls");
}

3.代码下载

链接: https://pan.baidu.com/s/1irv2cVgShCpZILEp5-VWEw?pwd=65qj

提取码: 65qj 

到此这篇关于C++分步实现职工管理系统详解的文章就介绍到这了,更多相关C++职工管理内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯