c++实现职工管理系统(基于多态和双链表)

本教程介绍如何使用C++构建一个基于多态的职工管理系统,涵盖普通员工、经理和老板三个角色,实现包括添加、显示、删除、修改、查找和排序等功能。系统通过文件存储职工信息,确保数据持久化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

职工管理系统可以用来管理公司内所有员工的信息


本教程主要利用C++来实现一个基于多态的职工管理系统


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


普通员工职责:完成经理交给的任务
经理职责:完成老板交给的任务,并下发任务给员工
老板职责:管理公司所有事务


管理系统中需要实现的功能如下:

1退出管理程序:退出当前管理系统

2增加职工信息:实现批量添加职工功能,将信息录入到文件中。

职工信息为∶职工编号、姓名、部门编号·显示职工信息:显示公司内部所有职工的信息
删除离职职工:按照编号删除指定的职工

3修改职工信息:按照编号修改职工个人信息

4查找职工信息:按照职工的编号或者职工的姓名进行查找相关的人员信息·

5按照编号排序:按照职工编号,进行排序,排序规则由用户指定

6清空所有文档:清空文件中记录的所有职工信息(清空前需要再次确认,防止误删)
 

成品如下:

 此项目用五个文件分别实现功能

头文件1

#pragma once
#include <iostream>
#include <string>
using namespace std;

//职工抽象类
class Worker
{
public:
	//显示个人信息
	virtual void showInfo() = 0;
	//获取岗位名称
	virtual string getDeptName() = 0;

	//职工编号
	int m_ID;
	//职工姓名
	string m_Name;
	//部门编号
	int m_DeptID;
};

//普通员工类
class Employee : public Worker
{
public:
	//构造函数
	Employee(int id, string name, int dId);
	//显示个人信息
	virtual void showInfo();
	//获取岗位名称
	virtual string getDeptName();
};

//经理类
class Manager : public Worker
{
public:
	//构造函数
	Manager(int id, string name, int dId);
	//显示个人信息
	virtual void showInfo();
	//获取岗位名称
	virtual string getDeptName();
};

//老板类
class Boss : public Worker
{
public:
	//构造函数
	Boss(int id, string name, int dId);
	//显示个人信息
	virtual void showInfo();
	//获取岗位名称
	virtual string getDeptName();
};

头文件2

#pragma once  //防止头文件重复包含

#include <iostream>
#include <fstream>
#include <string>
using namespace std;

#include "worker.h"

#define FILENAME "empFile.txt"

class Node
{
	friend class LinkedList;
public:
	Worker* m_Data_Worker;

private:
	Node* preptr;
	Node* postptr;
};

class LinkedList
{
public:
	LinkedList();
	~LinkedList();
	void newNodeToEnd(int ID, string name, int dSelect);
	Node* findNode(int ID);
	Node* findNode(string name);
	bool delNode(int ID);
	void showNode();
	void showNode(Node* p);
	void sortNode(int way);
	void cleanList();
	void save();

	int nodeNum;

private:
	Node node;
	//p: 管理当前节点,pBefore: 管理前一个节点,pAfter: 管理后一个节点,ptr: 分配内存的指针,h: 头节点,e: 尾节点
	Node* pBefore, * p, * pAfter, * ptr, * h, * e;
};

class WorkerManager
{
public:
	WorkerManager();
	~WorkerManager();

	void Show_Menu();
	void exitSystem();
	void Add_Emp();
	void Show_Emp();
	void Del_Emp();
	void Mod_Emp();
	void Find_Emp();
	void Sort_Emp();
	void Clean_File();

	LinkedList list;
};

源文件1

#include "worker.h"

//普通员工类
//构造函数
Employee::Employee(int id, string name, int dId)
{
	this->m_ID = id;
	this->m_Name = name;
	this->m_DeptID = dId;
}

//显示个人信息
void Employee::showInfo()
{
	cout << "职工编号:" << this->m_ID << "\t";
	cout << "姓名:" << this->m_Name << "\t";
	cout << "岗位:" << this->getDeptName() << "\t";
	cout << "岗位职责: 完成经理交给的任务" << endl;
}

//获取岗位名称
string Employee::getDeptName()
{
	return string("员工");
}

//经理类
员工管理系统】 问题描述:每个员工的信息包括:编号、姓名、性别、出生年月、学历、职务、电话、住址等。系统能够完成员工信息的查询、更新、插入、删除、排序等功能。 基本要求:排序:按不同关键字,对所有员工的信息进行排序;查询:按特定条件查找员工;更新,按编号对某个员工的某项信息进行修改;插入,加入新员工的信息;删除,按编号删除已离职的员工的信息。 选作内容:实现图形用户界面。 通过链表实现 数据结构: #include #include #include #include #include using namespace std; typedef struct workers{ char name[15];//姓名 char department[18];//单位 char gender;//性别 unsigned int age;//年龄 unsigned long long telephone;//电话 unsigned long wage;//工资 unsigned long num;//职工号 struct workers *next; }*Linklist,Lnode; void frist_print() { printf("\t\t⊙▽⊙ ⊙▽⊙ ⊙▽⊙ ⊙▽⊙ ⊙▽⊙ ⊙▽⊙ \n\n"); printf("\t\t\t欢迎进入员工管理系统\n"); } void menu() { printf("\n\t\t^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n"); printf("\t\t \t ◎1.创建员工信息\t \n"); printf("\t\t \t ◎2.插入员工信息\t \n"); printf("\t\t \t ◎3.修改员工信息\t \n"); printf("\t\t \t ◎4.删除员工信息\t \n"); printf("\t\t \t ◎5.查询员工信息\t \n"); printf("\t\t \t ◎6.员工信息排序\t \n"); printf("\t\t \t ◎7.显示员工信息\t \n"); printf("\t\t \t ◎8.员工工资情况\t \n"); printf("\n\t\t^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n"); printf("注意:输入均以回车作为结束\n"); printf("please choise 1--8:\t "); //putchar(12); } void Inset(Linklist Head){ Linklist s,L; unsigned int agee; unsigned long wagee,numm;
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值