c酒店管理系统代码_酒店管理系统

c酒店管理系统代码_酒店管理系统主要功能:1.添加员工信息2.显示员工信息3.删除员工信息4.修改员工信息5.查找员工信息6.员工信息排序7.清空数据(1)显示数据(2)修改数据(3)查找数据(4)信息排序部分代码展示:workerManager.cpp。需要完整代码可以留邮箱,有时间就发#include”stdafx.h”#include”work…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

主要功能:

1.添加员工信息

2.显示员工信息

3.删除员工信息

4.修改员工信息

5.查找员工信息

6.员工信息排序

7.清空数据

(1)显示数据

c酒店管理系统代码_酒店管理系统

(2)修改数据

c酒店管理系统代码_酒店管理系统

c酒店管理系统代码_酒店管理系统

(3)查找数据

c酒店管理系统代码_酒店管理系统

(4)信息排序

c酒店管理系统代码_酒店管理系统

部分代码展示:workerManager.cpp。需要完整代码可以留邮箱,有时间就发

#include "stdafx.h"
#include "workerManager.h"

WorkerManager::WorkerManager()
{
	//1.文件不存在
	ifstream ifs;
	ifs.open(FILENAME, ios::in);//读文件
	if (!ifs.is_open())
	{
		//cout << "文件不存在" << endl;
		this->m_staffNum = 0;
	    this->m_staffArray = NULL;
		this->m_FileIsEmpty = true;
		ifs.close();
		return;
	}

	//2.文件存在,数据为空
	char ch;
	ifs >> ch;
	if (ifs.eof())
	{
		//cout << "文件为空!" << endl;
		this->m_staffNum = 0;
		this->m_staffArray = NULL;
		this->m_FileIsEmpty = true;
		ifs.close();
		return;
	}

	//3.文件存在数据
	int num = this->get_staffNum();
	this->m_staffNum = num;
	//开辟空间
	this->m_staffArray = new Worker*[this->m_staffNum];
	
	//将文件中的数据存在数组中
	this->init_staff();
}


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;
	cout << endl;
}

void WorkerManager::exitSystem()
{
	cout << "系统退出" << endl;
	system("pause");
	exit(0);
}

void WorkerManager::Add_staff()
{
	cout << "输入添加员工的数量:" << endl;
	int  addNum = 0;  //保存员工的数量

	cin >> addNum;
	if (addNum > 0)
	{
		//计算新空间的大小
		int newSize = this->m_staffNum + addNum;
		//开辟新空间
		Worker ** newSpace=new Worker *[newSize];

		//将原始数据拷贝到新空间中
		if (this->m_staffArray != NULL)
		{
			for (int i = 0; i < this->m_staffNum; i++)
			{
				newSpace[i] = this->m_staffArray[i];
			}
		}
		for (int i = 0; i < addNum; i++)
		{
			int id;
			string name;
			int dId;
			cout << "请输入第" << i + 1 << "个员工的编号:" << endl;
			cin >> id;
			//判断该编号是否存在
			int ret = this->IsExist(id);  
			if (ret != -1)
			{
				while (1)
				{
					cout << "该编号已存在,请重新输入编号:" << endl;
					cin >> id;
				    ret = this->IsExist(id);
					if (ret == -1)
					{
						break;
					}
				}
			}
			
			cout << "请输入第" << i + 1 << "个员工的姓名:" << endl;
			cin >> name;
			cout << "请输入该员工的岗位:" << endl;
			cout << "1.普通员工" << endl;
			cout << "2.经理" << endl;
			cout << "3.老板" << endl;
			cin >> dId;

			Worker *worker = NULL;
			switch (dId)
			{
			case 1:
				worker = new staff(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_staffNum + i] = worker;
		}
		//释放原有空间
		delete[] this->m_staffArray;
		//更改新空间的指向
		this->m_staffArray = newSpace;
		//更新新的员工数量
		this->m_staffNum = 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_staffNum; i++)  
	{
		ofs << this->m_staffArray[i]->m_Id << " "
			<< this->m_staffArray[i]->m_Name << " "
			<< this->m_staffArray[i]->m_dId << endl;
	}
	//关闭文件
	ofs.close();
}

int WorkerManager::get_staffNum()
{
	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_staff()
{
	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 staff(id, name, dId);
		}
		else if (dId == 2)
		{
			worker = new manager(id, name, dId);
		}
		else if (dId == 3)
		{
			worker = new boss(id, name, dId);
		}
		this->m_staffArray[index] = worker;
		index++;
	}
	ifs.close();
}

//显示员工数据
void WorkerManager::show_staff()   
{
	if (this->m_FileIsEmpty)
	{
		cout << "文件不存在或者记录为空" << endl;
	}
	else
	{
		for (int i = 0; i < m_staffNum; i++)
		{
			this->m_staffArray[i]->showInfo();
		}
	}
	system("pause");
	system("cls");
}
//
int WorkerManager::IsExist(int id)
{
	int index = -1;
	for (int i = 0; i < this->m_staffNum; i++)
	{
		if (this->m_staffArray[i]->m_Id == id)
		{
			index = i;
			break;
		}
	}
	return index;
}


//删除员工
void WorkerManager::Del_staff()
{
	if (this->m_FileIsEmpty)
	{
		cout << "文件不存在或者为空" << endl;
	}
	else
	{
		cout << "请输入删除员工的的编号:" << endl;
		int id = 0;
		cin >> id;

		int index = this->IsExist(id);
		if (index != -1)  //员工存在,删除
		{
			for (int i = index; i < this->m_staffNum - 1; i++)
			{
				this->m_staffArray[i] = this->m_staffArray[i + 1];
			}
			this->m_staffNum--; //更新员工的数量
			//文件数据同步
			this->save();
			cout << "删除成功" << endl;
		}
		else
		{
			cout << "该员工不存在" << endl;
		}
		//清屏操作
		system("pause");
		system("cls");
	}
}

//修改员工数据
void WorkerManager::Mod_staff()
{
	if (this->m_FileIsEmpty)
	{
		cout << "文件不存在或者为空" << endl;
	}
	else
	{
		cout << "请输入修改的职工编号:" << endl;
		int id;
		cin >> id;
		int ret=this->IsExist(id);
		if (ret != -1)
		{
			delete this->m_staffArray[ret];
			int newId = 0;
			string newName = " ";
			int newdId = 0;
			cout << "查找到" << id << "号职工,请输入新职工编号:" << endl;
			cin >> newId;
			cout << "请输入新的名字:" << endl;
			cin >> newName;
			cout << "请输入新的岗位" << endl;
			cout << "1.清洁员" << endl;
			cout << "2.经理" << endl;
			cout << "3.老板" << endl;
			cin >> newdId;
			Worker * worker = NULL;

			switch (newdId)
			{
			case 1:
				worker = new staff(newId, newName, newdId);
				break;
			case 2:
				worker = new manager(newId, newName, newdId);
				break;
			case 3:
				worker = new boss(newId, newName, newdId);
				break;
			default:
				break;
			}
			//更新数据到数组中
			this->m_staffArray[ret] = worker;
			cout << "修改成功" << endl;

			//保存到文件中
			this->save();
		}
		else
		{
			cout << "修改失败,查无此人" << endl;
		}
	}
	system("pause");
	system("cls");
}


//查找员工
void WorkerManager::Find_staff()
{
	if (this->m_FileIsEmpty)
	{
		cout << "文件不存在或者数据为空";
	}
	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 = IsExist(id);
			if (ret != -1)
			{
				cout << "查找成功!该员工信息如下:" << endl;
				this->m_staffArray[ret]->showInfo();
			}
			else
			{
				cout << "查无此人" << endl;
			}
		}
		else if (select == 2)
		{
			string name;
			cout << "请输入查找的职工名字:" << endl;
			cin >> name;
			//判断是否查到
			bool flag = false;//默认未找到
			for (int i = 0; i < m_staffNum; i++)
			{
				if (this->m_staffArray[i]->m_Name == name)
				{
					cout << "查找成功,职工编号为:"
						<< this->m_staffArray[i]->m_Id
						<< "该员工信息如下:" << endl;
					flag = true;
					this->m_staffArray[i]->showInfo();
				}
			}
			if (flag == false)
			{
				cout << "查无此人" << endl;
			}
		}
		else
		{
			cout << "查无此人" << endl;
		}
	}
	system("pause");
	system("cls");
}
//对员工编号进行排序
void WorkerManager::Sort_staff()  
{
	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 < m_staffNum; i++)
		{
			int minOrMax = i;  //最小值或者对大值的下标
			for (int j = i + 1; j < m_staffNum; j++)
			{
				if (select == 1) //升序
				{
					if (this->m_staffArray[minOrMax]->m_Id > this->m_staffArray[j]->m_Id)
					{
						minOrMax = j;
					}
				}
				else //降序
				{
					if (this->m_staffArray[minOrMax]->m_Id < this->m_staffArray[j]->m_Id)
					{
						minOrMax = j;
					}
				}
			}
			if (i != minOrMax)
			{
				Worker * temp = this->m_staffArray[i];
				this->m_staffArray[i] = this->m_staffArray[minOrMax];
				this->m_staffArray[minOrMax] = temp;
			}
		}
		cout << "排序成功!" << endl;
		this->show_staff();
		this->save();
	}
}

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_staffArray != NULL)
		{
			//删除堆区的每个对象
			for (int i = 0; i < this->m_staffNum; i++)
			{
				delete this->m_staffArray[i];
				this->m_staffArray[i] = NULL;
			}
			//删除堆区数组指针
			delete[] this->m_staffArray;
			this->m_staffArray = NULL;
			this->m_staffNum = 0;
			this->m_FileIsEmpty = true;
		}
		cout << "清空成功" << endl;
	}
	system("pause");
	system("cls");
}
WorkerManager::~WorkerManager()  //释放
{
	if (this->m_staffArray != NULL)
	{
		for (int i = 0; i < m_staffNum; i++)
		{
			delete this->m_staffArray[i];
			this->m_staffArray[i] = NULL;
		}
		delete[]this->m_staffArray;
		this->m_staffArray = NULL;
	}
}

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/189905.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • cmd输入java有效,输入javac无效解决方案

    cmd输入java有效,输入javac无效解决方案笔记本的系统是win1064bit的系统,按照网上的指导安装了jdk和jre运行cmd的时候,输入java会有输出,但是输入javac的时候就报javac不是内部或外部命令的错误。最终的解决办法是:cmd中输入:setpath="%JAVA_HOME%\bin"…

    2022年5月8日
    65
  • Swift-Moya 源码解析

    Swift-Moya 源码解析1 Moya 的定义 Moya 是一个高度抽象的网络库 他的理念是让你不用关心网络请求的底层的实现细节 只用定义你关心的业务 且 Moya 采用桥接和组合来进行封装 默认桥接了 Alamofire 使得 Moya 非常好扩展 让你不用修改 Moya 源码就可以轻易定制 官方给出几个 Moya 主要优点 编译时检查 APIendpoint 权限让你使用枚举定义各种不同 Target endpoints 把 stubs 当做一等公民对待 因此测试超级简单 2 Moya 的使用 Moya 的使用分成几步 首先需要先自定义一个

    2025年10月9日
    4
  • replay视频播放器_怎么让手机音乐跟视频一起放

    replay视频播放器_怎么让手机音乐跟视频一起放以前项目中需要播放在线视频和在线音频,当时就研究了一下。下面只显示核心代码。1.AVPlayer(负责视频操作,例如播放,暂停,声音的大小,跳到指定的时间)2.AVPlayerLayer(负责视频的可视化区域,视频的播放模式,注意是CALayer,不能接手触摸)3.AVPlayItem(表示AVPlayer播放的资源对象,可以监听其状态)全屏的实现有2种方式1.可以

    2022年4月19日
    87
  • mysql数据库备份方法有几种_MySQL几种方法的数据库备份

    mysql数据库备份方法有几种_MySQL几种方法的数据库备份MySQL有几个方法来备份最近博客一直想写点。可是不知道写什么,感觉自己近期的知识没有什么添加,今天想到了一篇能够写的博客。曾经试过依据data目录备份MySQL。可是从来没有成功过。前几天帮助朋友还原MySQL,最终成功的将备份的data目录还原成功了。MySQL数据库算是经常使用的数据库中最好使用的数据库了,对于备份的操作也不例外。所以今天分享一下MySQL数据库的备份的几种方式。方式一:使用…

    2022年5月14日
    47
  • vue中的横向排列_vue + ElementUI 的横向表格代码「建议收藏」

    vue中的横向排列_vue + ElementUI 的横向表格代码「建议收藏」{{tableData[index*2-2].key}}{{tableData[index*2-2].value}}{{tableData[index*2-1]!==undefined?tableData[index*2-1].key:‘‘}}{{tableData[index*2-1]!==undefined?tableData[index*2-1].value:‘‘}}…

    2022年8月11日
    55
  • 国产操作系统(Linux)技术流派[通俗易懂]

    国产操作系统(Linux)技术流派[通俗易懂]图1Linux发行版如上图所示目前主流的Linux发行版大体可以分为两类:一类是简称为RPM系,另一类是简称为DEB系。基中RPM系是以Redhat为代表,其主导发行的包括:服务器商业版:RedhatEnterpriseLinux服务器社区版:Centos社区版:FedoraCentos以它是来自于RedhatEnterpriseLinux依照开放源代码规定释出的源代码所编译而成。Fedora则是RedhatEnterpriseLinux是…

    2022年5月16日
    52

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号