C++实践项目一:基于多态搭建企业员工管理系统,实现信息的增、删、改、查、排序

C++实践项目一:基于多态搭建企业员工管理系统,实现信息的增、删、改、查、排序

基于多态的信息管理系统是典型的团体管理系统,对于任何存在明显的角色分工的团体和组织(学校的学生教职工、政府单位各部门等)都可以以此进行拓展,本系统是基于C++面向对象中多态与动态绑定的机制实现的。

多态性的概述

多态是指同样的消息被不同类型的对象接受时导致不同的行为。所谓信息是指对类的成员函数的调用,不同的行为是指不同的实现,也就是调用了不同的函数。
简单的例子:运算符
使用同样的“+”就可以实现整型数之间、浮点数之间、双精度浮点数之间的假发,以及这几种数据类型混合的加法运算。
总结一句话:多态就是一个接口,多种实现
针对企业职工而言,一般由职员、经理、董事长等等组成。三种类型的职工有相同的属性(比如都会有职员编号、姓名和部门等等),根据不同的角色分工也有不同的行为(比如职员就是做任务,经理是分任务、董事长是定任务等等)。
接下来,开始介绍代码的实现。
先上图,头文件是做函数的声明,源文件做函数的具体实现
在这里插入图片描述
相关源码如下:
链接:

https://pan.baidu.com/s/1f_yN6PYeuFUY1XIVEHzDPA

提取码:

4ocn

首先介绍一下该职工管理系统:
公司中职工分为三类:普通员工、经理、董事长,显示信息时,需要显示职工编号、职工姓名、职工岗位职责。
职工岗位职责:
普通员工——完成经理交给的任务
经理——完成董事长交给的任务,并下发任务给员工
董事长——管理公司所有事务

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

  • 退出管理程序:退出当前管理系统
  • 增加职工信息:实现批量增加职工功能,将信息(编号、姓名、部门)录入文件
  • 显示职工信息:显示公司内部所有员工信息
  • 删除离职员工:按照编号删除指定员工
  • 修改职工信息:按照编号修改职工信息
  • 职工信息排序:按编号的升序和降序进行排序
  • 信息清楚:删除文件及系统信息,释放空间

对源码进行说明:

worker.h

首先,创建一个职工抽象类Worker类,接下来依此作为基类,对不同的职员类进行派生。这里声明了两个纯虚函数:
virtual void showInfo() = 0;
virtual string getDEPTNAME() = 0;

#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;

};

接下来,在Worker基类的基础上创建Employee、Manager、Boss三个派生类,如下:

employee.h

#pragma once  //防止头文件重复包含
#include<iostream>  //包含输入输出流头文件
#include<string>
#include"worker.h"  //将基类的头文件加入


using namespace std;  //使用标准命名空间

class Employee :public Worker
{
public:
	//构造函数
	Employee(int id, string name, int did );
	//显示个人信息
	virtual void showInfo();   //纯虚函数,只做声明,不定义


	//获取岗位名称
	virtual string getDEPTNAME();
	
};

manager.h

#pragma once  //防止头文件重复包含
#include<iostream>  //包含输入输出流头文件
#include<string>
#include"worker.h"  //将基类的头文件加入


using namespace std;  //使用标准命名空间

//经理类
class Manager :public Worker
{
public:
	//构造函数
	Manager(int id,string name,int did);
	//显示个人信息
	virtual void showInfo();   //纯虚函数,只做声明,不定义


	//获取岗位名称
	virtual string getDEPTNAME();

};

Boss.h

#pragma once  //防止头文件重复包含
#include<iostream>  //包含输入输出流头文件
#include<string>
#include"worker.h"  //将基类的头文件加入


using namespace std;  //使用标准命名空间

//经理类
class Boss :public Worker
{
public:
	//构造函数
	Boss(int id, string name, int did);
	//显示个人信息
	virtual void showInfo();   //纯虚函数,只做声明,不定义


	//获取岗位名称
	virtual string getDEPTNAME();

};

接下来,对三个派生类进行具体实现

employee.cpp

#include"employee.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; 
	cout << "\t职工姓名:" << this->m_NAME;
	cout << "\t岗位:" << this->getDEPTNAME();
	cout << "\t岗位职责:完成经理分配的任务" << endl;
}

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

manager.cpp

#include"Manager.h"

//构造函数
Manager::Manager(int id, string name, int did)
{
	this->m_ID = id;
	this->m_NAME = name;
	this->m_DEPTID = did;

}
//显示个人信息
void Manager::showInfo()   //纯虚函数,只做声明,不定义
{
	cout << "职工编号: " << this->m_ID
		<< "\t职工姓名:" << this->m_NAME
		<< "\t岗位:" << this->getDEPTNAME()
		<< "\t岗位指责:  完成老板给的任务,并且下发任务给普通员工" << endl;
 }


//获取岗位名称
string Manager::getDEPTNAME()
{
	return string("经理");

 }

Boss.cpp

#include"Boss.h"

//构造函数
Boss::Boss(int id, string name, int did)
{
	this->m_ID = id;
	this->m_NAME = name;
	this->m_DEPTID = did;
}
//显示个人信息
 void Boss::showInfo()  //纯虚函数,只做声明,不定义
{
	 cout << "职工编号: " << this->m_ID
		 << "\t职工姓名:" << this->m_NAME
		 << "\t岗位:" << this->getDEPTNAME()
		 << "\t岗位指责:  管理公司所有事物" << endl;
}


//获取岗位名称
 string Boss::getDEPTNAME()
{
	 return ("总裁");
}

接下来,要建立职工信息的功能实现
建立一头文件,声明需要实现的各个功能函数

workerManager.h

#pragma once  //防止头文件重复包含
#include<iostream>  //包含输入输出流头文件
#include"worker.h"
#include"employee.h"
#include"manager.h"
#include"Boss.h"

#include<fstream>
#define FILENAME "empFile.txt"

using namespace std;  //使用标准命名空间

class WorkerManager
{
public:

	//构造函数
	WorkerManager();  

	//展示菜单的,只做声明
	void Show_Menu();

	//退出系统,在.h文件里面做声明就可以
	void ExitSystem();

	//记录职工的人数
	int m_EmpNum;

	//职工数组的指针
	Worker ** m_EmpArray;

	//添加职工
	void Add_Emp();

	//保存文件
	void save();

	//判断文件是否为空
	bool m_FileIsEmpty;

	//统计文件中的人数
	int get_EmpNum();

	//初始化职工
	void init_Emp();

	//显示职工的成员函数
	void show_Emp();

	//删除职工
	void Del_EmP();

	//判断职工是否存在 如果存在返回职工所在数组中的位置,不存在返回 -1
	int IsxExist(int id);

	//修改职工
	void Mod_Emp();

	//查找职工
	void Find_Emp();

	//按照职工编号进行排序
	void Sort_Emp();

	//清空文件
	void Clean_File();

	//析构函数
	~WorkerManager();
};

职工功能的具体实现:

#include"workerManager.h"

WorkerManager::WorkerManager()
{
	//1、文件不存在
	ifstream ifs;
	ifs.open(FILENAME,ios::in); //读文件

	if (!ifs.is_open())
	{
		cout << "文件不存在" << endl;
		//初始化属性
		//初始化人数为零
		this->m_EmpNum = 0;
		//初始化数组指针
		this->m_EmpArray = NULL;
		//初始化文件为空
		this->m_FileIsEmpty = true;
		ifs.close();
		return;
	}

	//2.文件存在,数据为空
	char ch;
	ifs >> ch;  //都走仅有的一个字符
	if (ifs.eof())
	{
		//文件为空
		cout << "文件为空" << endl;
		//初始化人数为零
		this->m_EmpNum = 0;
		//初始化数组指针
		this->m_EmpArray = NULL;
		//初始化文件为空
		this->m_FileIsEmpty = true;
		ifs.close();
		return;
	}

	//3、当文件存在且记录数据
	int num = this->get_EmpNum();
	cout << "职工人数:" << num << endl;
	this->m_EmpNum = num;

	//开辟好空间
	this->m_EmpArray = new Worker*[this->m_EmpNum];
	//将文件中的数据,存到数组中
	this->init_Emp();
	

	//测试代码
	//for (int i = 0; i < this->m_EmpNum; i++)
	//{
	//	cout << "  职工编号: " << this->m_EmpArray[i]->m_ID
	//		<< "  姓名:" << this->m_EmpArray[i]->m_NAME
	//		<< "  部门编号: " << this->m_EmpArray[i]->m_DEPTID << endl;
	//}



}

void WorkerManager::Show_Menu()
{
	cout << "********************************************" << endl;
	cout << "**********欢迎使用职工管理系统**************" << endl;
	cout << "***********0.退出管理程序*******************" << endl;
	cout << "***********1.增加职工信息*******************" << endl;
	cout << "***********2.显示职工信息*******************" << endl;
	cout << "***********3.删除职工信息*******************" << endl;
	cout << "***********4.修改职工信息*******************" << endl;
	cout << "***********5.查找职工信息*******************" << endl;
	cout << "***********6.按照编号排序*******************" << endl;
	cout << "***********7.清空所有文档*******************" << endl;
	cout << "********************************************" << endl;


}

void WorkerManager::ExitSystem()
{
	cout << "欢迎下次使用" << endl;
	system("pause");
	exit(0);  //退出程序
}

//添加职工
void WorkerManager::Add_Emp()
{
	cout << "请输入添加职工的数量: " << endl;
	int addNum = 0; //保存用户的输入数量
	cin >> addNum;
	if (addNum > 0)
	{
		//添加
		//计算新空间的大小
		int newSize = this->m_EmpNum + addNum; //新空间人数=原来记录的人数+新增的人数
	
		//开辟新空间——动态扩展
		Worker **newSpace=new Worker *[newSize];
	
		//将原来空间下的数据。拷贝到新的空间中
		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;
			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);

			default:
				break;
			}

			//将创建的职工指针,保存到数组中,后续的员工加入
			newSpace[this->m_EmpNum + i] = worker;

		}
		//释放原有空间
		delete[] this->m_EmpArray;

		//更改新空间的指向
		this->m_EmpArray = newSpace;

		//更新新空间的人数
		this->m_EmpNum = newSize;

		//更新员工不为空
		this->m_FileIsEmpty = false;
		//提示添加成功
		cout << "成功添加" << addNum << "名新职工!" << endl;
	    
		//保存数据到文件中
		this->save();
	}
	else
	{
		cout << " 输入的数据有误" << endl;
	}

	//按任意键 清屏回到上级目录
	system("pause");
	system("cls");

}

void WorkerManager::save()
{
	ofstream ofs;
	ofs.open(FILENAME,ios::out); //用输出的方式打开文件  -写文件

	//将每一个人的数据写入到文件中
	for (int i = 0; i < this->m_EmpNum; i++)
	{
		ofs << this->m_EmpArray[i]->m_ID << " "
			<< this->m_EmpArray[i]->m_NAME << " "
			<< this->m_EmpArray[i]->m_DEPTID << endl;
	}

	//关闭文件
	ofs.close();
}

//统计文件中的人数
int WorkerManager::get_EmpNum()
{
	ifstream ifs;
	ifs.open(FILENAME,ios::in); //打开文件 读文件

	int id;
	string name;
	int did;
	int num = 0;
	while (ifs >> id && ifs >> name && ifs >> did)
	{
		//统计人数变量
		num++;
	}
	return num;
}


void WorkerManager::init_Emp()
{
	ifstream ifs;
	ifs.open(FILENAME,ios::in);
	int id;
	string name;
	int did;
	int index = 0;

	while (ifs >> id && ifs >> name && ifs >> did)
	{
		Worker *worker = NULL;
		if (did == 1) //普通职工
		{
			worker = new Employee(id,name,did);
		}
		else if (did == 2) //经理
		{
			worker = new Manager(id,name,did);
		}
		else
		{
			worker = new Boss(id,name,did);
		}
		this->m_EmpArray[index] = worker;
		index++;
	}
	//关闭文件
	ifs.close();
}


void WorkerManager::show_Emp()
{
	//判断文件是否为空
	if (this->m_FileIsEmpty)
	{
		cout << "文件不存在或记录为空" << endl;
	}
	else
	{
		for (int i = 0; i < m_EmpNum; i++)
		{
			this->m_EmpArray[i]->showInfo();
		}
	}
	//按任意键清屏
	system("pause");
	system("cls");
}


//删除职工
void WorkerManager::Del_EmP()
{
	if (this->m_FileIsEmpty)
	{
		cout << "文件不存在或记录为空" << endl;
	}
	else
	{
		//按照职工变换删除
		cout << "请输入想要删除的职工编号:" << endl;
		int id = 0;
		cin >> id;
		int index = this->IsxExist(id);

		if (index != -1) //说明职工存在,并且要删除掉index位置上的职工
		{
			for (int i = index; i < this->m_EmpNum; i++)
			{
				//数据前移
				this->m_EmpArray[i] = this->m_EmpArray[i + 1];
			}
			this->m_EmpNum--; //更新数组中人员个数
			//同步更新到文件中
			this->save();
			cout << "删除成功!" << endl;
		}
		else
		{
			cout << "删除失败,未找到职工" << endl;
		}
	}
	//按任意键清屏
	system("pause");
	system("cls");
}

//判断职工是否存在 如果存在返回职工所在数组中的位置,不存在返回 -1
int  WorkerManager::IsxExist(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;
}

//修改职工
void WorkerManager::Mod_Emp()
{
	if (this->m_FileIsEmpty)
	{
		cout << "文件不存在或记录为空" << endl;
	}
	else
	{
		cout << "请输入修改职工的编号" << endl;
		int id;
		cin >> id;

		int ret=this->IsxExist(id);
		if (ret != -1)
		{
			//查找到编号的职工
			cout << "查找到编号的职工" << endl;
			delete this->m_EmpArray[ret];

			int newId=0;
			string newNAME = "";
			int dselect = 0;

			cout << "查到:" << id << "号职工,请输入新职工号:" << 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,dselect);
				break;
			case 2:
				worker = new Manager(newId, newNAME, dselect);
				break;
			case 3:
				worker = new Boss(newId, newNAME, dselect);
				break;

			default:
				break;
			}
			this->m_EmpArray[ret] = worker;
			cout << "修改成功" << endl;
			//保存到文件中
			this->save();
		}
		else
		{
			cout << "修改失败,查无此人" << endl;
		}
		system("pause");
		system("cls");
	}
}


//查找职工
void WorkerManager::Find_Emp()
{
	//判断是否为空文件
	if (this->m_FileIsEmpty)
	{
		cout << "文件不存在或者为空" << endl;
	}
	else
	{
		cout << "请输入查找方式" << endl;
		cout << "1、按照职工的编号查找" << endl;
		cout << "2、按照职工的姓名查找" << endl;
	}
	int select = 0;
	cin >> select;

	if (select == 1)
	{
		//按照编号查询
		int id;
		cout << "请输入查找职工的编号:" << endl;
		cin >> id;

		int ret = IsxExist(id);
		if (ret != -1)
		{
			//找到职工
			cout << "查找成功" << endl;
			this->m_EmpArray[ret]->showInfo();
		}
		else
		{
			cout << "查找失败,查无此人" << endl;
		}
	}
	else if (select == 2)
	{
		//按照姓名查
		string name;
		cout << "请输入查找的姓名" << endl;
		cin >> name;
		//添加一个是否查到的标志
		bool flag = false;
		for (int i = 0; i < this->m_EmpNum; i++)
		{
			if (this->m_EmpArray[i]->m_NAME == name)
			{
				flag = true;
				cout << "查找成功" << endl;
				cout << "职工编号为:" << this->m_EmpArray[i]->m_ID << "号职工信息如下:" << endl;
				this->m_EmpArray[i]->showInfo();
			}
		}
		if (flag == false)
		{
			cout << "查找失败,查无此人" << endl;
		}
	}
	else
	{
		cout << "输入错误" << endl;
	}

	system("pause");
	system("cls");
}


//按照职工编号进行排序
void WorkerManager::Sort_Emp()
{
	if (this->m_FileIsEmpty)
	{
		cout << "文件不存在或为空" << endl;
		system("pause");
		system("cls");
	}
	else
	{
		cout << "请选择排序方式:" << endl;
		cout << "1、按照职工编号进行升序" << endl;
		cout << "2、按照职工编号进行降序" << endl;
	   
		int select = 0;
		cin >> select;
		for (int i = 0; i < this->m_EmpNum; i++)
		{
			int minOrMax = i; //生命最小值或最大值的下标
			for (int j = i; j < this->m_EmpNum; j++)
			{
				if (select == 1) //升序
				{
					if (this->m_EmpArray[minOrMax]->m_ID > this->m_EmpArray[j]->m_ID)
					{
						minOrMax = j;
					}
				}
				else  //降序
				{
					if (this->m_EmpArray[minOrMax]->m_ID < this->m_EmpArray[j]->m_ID)
					{
						minOrMax = j;
					}
				}
			}
			//判断一开始认定的最小值和最大值是不是计算的最小值和最大值,如果不是就交换
			if (i != minOrMax)
			{
				Worker*temp = this->m_EmpArray[i];
				this->m_EmpArray[i] = this->m_EmpArray[minOrMax];
				this->m_EmpArray[minOrMax] = temp;
			}
		}

		cout << "排序成功!排序后的结果为:" << endl;
		this->save();
		this->show_Emp();
	}
  }

//清空文件
void WorkerManager::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_EmpArray = NULL;
			this->m_EmpNum = 0;
			this->m_FileIsEmpty = true;
		}
		cout << "清空成功!" << endl;

	}
	system("pause");
	system("cls");

}



WorkerManager::~WorkerManager()
{
	if (this->m_EmpArray != NULL)
	{
		//将每一个元素进行清空
		for (int i = 0; i < this->m_EmpNum; i++)
		{
			delete this->m_EmpArray[i];
		}
		//释放堆区的数据
		delete[] this->m_EmpArray;
		this->m_EmpArray = NULL;
	}
}

最后就是,主函数所在的源文件

管理系统.cpp

#include<iostream>
#include"workerManager.h"

#include"worker.h"
#include"employee.h"
#include"manager.h"
#include"Boss.h"

using namespace std;

int main()
{

	测试代码
	//Worker *worker = NULL;
	//worker = new Employee(1,"张三",1);
	//worker->showInfo();
	//delete worker;

	//worker = new Manager(2,"李四",2);
	//worker->showInfo();
	//delete worker;

	//worker = new Boss(3, "李四", 3);
	//worker->showInfo();
	//delete worker;


	//实例化管理者对象
	WorkerManager wm;
	//存储用户的选项
	int choice = 0;

	while (1)
	{

		//调用展示菜单的成员函数
		wm.Show_Menu();
		cout << "请输入您的选择" << endl;
		cin >> choice;

		switch (choice)
		{
		case 0:
			wm.ExitSystem();
			break;

		case 1:  //添加职工
			wm.Add_Emp();
			break;

		case 2:  //显示职工
			wm.show_Emp();
			break;

		case 3:  //删除职工
		{
			wm.Del_EmP();
			break;
		}

		case 4:   //修改职工
			wm.Mod_Emp();
			break;

		case 5:  //查找职工
			wm.Find_Emp();
			break;

		case 6:  //排序职工
			wm.Sort_Emp();
			break;

		case 7:  //清空文档
			wm.Clean_File();
			break;

		default:
			system("cls");
			break;
	}
}
	system("pause");
	return 0;
}

系统测试

1、添加职工信息
在这里插入图片描述
2、显示职工信息
在这里插入图片描述
3、删除职工信息
在这里插入图片描述
4、修改职工信息
在这里插入图片描述
5、查找职工信息
在这里插入图片描述
6、排序
升序:
在这里插入图片描述
降序:
在这里插入图片描述
7.清空文件
初始文件信息:
在这里插入图片描述
进行操作:
在这里插入图片描述
现文件状态:
在这里插入图片描述
至此,基于多态实现的职工管理系统介绍完毕~~

一、目的和要求 1、目的: (1)要求学生达到熟练掌握C++语言的基本知识和技能; (2)基本掌握面向对象程序设计的基本思路和方法; (3)能够利用所学的基本知识和技能,解决简单的面向对象程序设计问题。 2、基本要求: (1)要求利用面向对象的方法以及C++的编程思想来完成系统的设计; (2)要求在设计的过程中,建立清晰的类层次; (3)在系统中至少要定义四个类,每个类中要有各自的属性和方法; (4)在系统的设计中,至少要用到面向对象的一种机制。 3、创新要求: 在基本要求达到后,可进行创新设计,如根据找结果进行修的功能及设计出比较友好的界面等。 4、写出设计说明书 二、设计方法和基本原理: 1、问题描述(功能要求): 某小型公司,主要有四类人员:经理、兼职技术人员、销售经理和兼职推销员。现在,需要存储这些人员的姓名、编号、级别、当月薪水,计算月薪总额并显示全部信息。 要求: 1)其中,人员编号在生成人员信息时同时生成,每输入一个人员信息编号顺序加1。 2)程序对所有人员有提升级别的功能 3)月薪的计算方法是:经理拿固定月薪,兼职技术人员按工作小时数领取月薪,兼职推销员的报酬按该推销员当月销售额提成 ,销售经理既拿固定月薪也领取销售提成。 4)能按姓名或者编号显示、找、加、除和保存各类人员
员工管理系统】 问题描述:每个员工信息包括:编号、姓名、性别、出生年月、学历、职务、电话、住址等。系统能够完成员工信息询、更新、插入、除、排序等功能。 基本要求:排序:按不同关键字,对所有员工信息进行排序询:按特定条件员工;更新,按编号对某个员工的某项信息进行修;插入,加入新员工信息除,按编号除已离职的员工信息。 选作内容:实现图形用户界面。 通过链表实现 数据结构: #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;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值