首页 > 其他分享 >2.通讯录管理系统

2.通讯录管理系统

时间:2025-01-18 12:45:55浏览次数:1  
标签:cout 管理系统 ret name abs 通讯录 personArray Size

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

#define MAX 1000

void showMenu() {
	cout << "***************************" << endl;
	cout << "*****  1、添加联系人  *****" << endl;
	cout << "*****  2、显示联系人  *****" << endl;
	cout << "*****  3、删除联系人  *****" << endl;
	cout << "*****  4、查找联系人  *****" << endl;
	cout << "*****  5、修改联系人  *****" << endl;
	cout << "*****  6、清空联系人  *****" << endl;
	cout << "*****  0、退出通讯录  *****" << endl;
	cout << "***************************" << endl;
}


struct Person
{
	string m_Name;
	int m_Sex;
	int m_Age;
	string m_Phone;
	string m_Addr;
};


struct Addressbooks
{
	Person personArray[MAX];
	int m_Size;
};


void addPerson(Addressbooks *abs) {
	if (abs->m_Size == MAX) {
		cout << "通讯录已满,无法添加" << endl;
		return;
	}
	else {
		string name;
		cout << "请输入姓名:" << endl;
		cin >> name;
		abs->personArray[abs->m_Size].m_Name = name;
		
		cout << "请输入性别:" << endl;
		cout << "1 -- 男" << endl;
		cout << "1 -- 女" << endl;

		int sex = 0;
		while (true) {
			cin >> sex;
			if (sex == 1 || sex == 2) {
				abs->personArray[abs->m_Size].m_Sex = sex;
				break;
			}
			cout << "输入有误,请重新输入" << endl;
		}

		cout << "请输入年龄" << endl;
		int age = 0;
		cin >> age;
		abs->personArray[abs->m_Size].m_Age = age;

		cout << "请输入联系电话" << endl;
		string phone = "";
		cin >> phone;
		abs->personArray[abs->m_Size].m_Phone = phone;

		cout << "请输入家庭住址" << endl;
		string address;
		cin >> address;
		abs->personArray[abs->m_Size].m_Addr = address;

		abs->m_Size++;

		cout << "添加成功" << endl;
		system("pause");
		system("cls");
	}
}


void showPerson(Addressbooks* abs) {
	if (abs->m_Size == 0) {
		cout << "当前记录为空" << endl;
	}
	else {
		for (int i = 0; i < abs->m_Size; i++) {
			cout << "姓名:" << abs->personArray[i].m_Name << "\t";
			cout << "性别" << (abs->personArray[i].m_Sex == 1 ? "男" : "女") << "\t";
			cout << "年龄:" << abs->personArray[i].m_Age << "\t";
			cout << "电话:" << abs->personArray[i].m_Phone << "\t";
			cout << "住址:" << abs->personArray[i].m_Addr << endl;
		}
	}
	system("pause");
	system("cls");
}


int isExist(Addressbooks* abs, string name) {
	for (int i = 0; i < abs->m_Size; i++) {
		if (abs->personArray[i].m_Name == name) {
			return i;
		}
	}
	return -1;
}


void deletePerson(Addressbooks *abs) {
	cout << "请输入您要删除的联系人" << endl;
	string name;
	cin >> name;
	int ret = isExist(abs, name);
	if (ret != -1) {
		for (int i = ret; i < abs->m_Size; i++) {
			abs->personArray[i] = abs->personArray[i + 1];
		}
		abs->m_Size--;
		cout << "删除成功" << endl;
	}
	else {
		cout << "查无此人" << endl;
	}
	system("pause");
	system("cls");
}


void findPerson(Addressbooks *abs) {
	cout << "请输入您要查找的联系人" << endl;
	string name;
	cin >> name;

	int ret = isExist(abs, name);
	if (ret != -1) {
		cout << "姓名:" << abs->personArray[ret].m_Name << "\t";
		cout << "性别:" << abs->personArray[ret].m_Sex << "\t";
		cout << "年龄:" << abs->personArray[ret].m_Age << "\t";
		cout << "电话:" << abs->personArray[ret].m_Phone << "\t";
		cout << "住址:" << abs->personArray[ret].m_Addr << endl;
	}
	else {
		cout << "查无此人" << endl;
	}
	system("pause");
	system("cls");
}


void modifyPerson(Addressbooks *abs) {
	cout << "请输入您要修改的联系人" << endl;
	string name;
	cin >> name;

	int ret = isExist(abs, name);
	if (ret != -1) {
		string name;
		cout << "请输入姓名:" << endl;
		cin >> name;
		abs->personArray[ret].m_Name = name;

		cout << "请输入性别" << endl;
		cout << "1 -- 男" << endl;
		cout << "2 -- 女" << endl;
		int sex = 0;
		while (true) {
			cin >> sex;
			if (sex == 1 || sex == 2) {
				abs->personArray[ret].m_Sex = sex;
				break;
			}
			cout << "输入有误,请重新输入" << endl;
		}

		cout << "请输入联系电话:" << endl;
		string phone = "";
		cin >> phone;
		abs->personArray[ret].m_Phone = phone;

		cout << "请输入家庭住址:" << endl;
		string address;
		cin >> address;
		abs->personArray[ret].m_Addr = address;

		cout << "修改成功" << endl;
	}
	else {
		cout << "查无此人" << endl;
	}
	system("pause");
	system("cls");
}


void cleanPerson(Addressbooks *abs) {
	abs->m_Size = 0;  // 逻辑清空
	cout << "此通讯录已清空" << endl;
	system("pause");
	system("cls");
}


int main() {

	Addressbooks abs;
	abs.m_Size = 0;

	int select = 0;

	while (true) {
		showMenu();
		
		cin >> select;

		switch (select)
		{
		case 1:  // 添加联系人
			addPerson(&abs);
			break;
		case 2:  // 显示联系人
			showPerson(&abs);
			break;
		case 3:  // 删除联系人
			deletePerson(&abs);
			break;
		case 4:  // 查找联系人
			findPerson(&abs);
			break;
		case 5:  // 修改联系人
			modifyPerson(&abs);
			break;
		case 6:  // 清空联系人
			cleanPerson(&abs);
			break;
		case 0:
			cout << "欢迎下次使用" << endl;
			return 0;
			break;
		default:  // 退出通讯录
			break;
		}
	
	}
	return 0;
}

标签:cout,管理系统,ret,name,abs,通讯录,personArray,Size
From: https://www.cnblogs.com/lotuslaw/p/18678344

相关文章

  • 计算机毕业设计Springboot奶茶店销售管理系统设计 基于Springboot的奶茶店销售管理系
    计算机毕业设计Springboot奶茶店销售管理系统设计c1bs36ep(配套有源码程序mysql数据库论文)本套源码可以先看具体功能演示视频领取,文末有联xi可分享随着现代生活节奏的加快和消费者偏好的持续演变,奶茶店作为流行的饮品消费场所,其市场竞争激烈,同时面临着多样化和个性化的消......
  • 基于springboot头条文章管理系统[编号:project44558]
    收藏关注不迷路!!......
  • node.js毕设工商学院宿舍管理系统论文+程序
    本系统(程序+源码+数据库+调试部署+开发环境)带文档lw万字以上,文末可获取源码系统程序文件列表开题报告内容选题背景关于高校宿舍管理系统的研究,现有研究主要以满足基本的住宿安排和人员信息管理为主。在国外,一些先进的高校宿舍管理系统已实现高度智能化,涵盖从入住到离校的......
  • JSP旅游资源及线路管理系统uun71(程序+源码+数据库+调试部署+开发环境)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容一、研究背景与意义随着旅游业的蓬勃发展,旅游资源的有效管理和线路的优化设计成为提升旅游体验的关键。传统的旅游资源管理方式存在信息更新慢、线......
  • JSP律师咨询信息管理系统y8036(程序+源码+数据库+调试部署+开发环境)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容项目名称:律师咨询信息管理系统开发项目背景:随着社会法治化进程的推进,公众对法律咨询服务的需求日益增长。传统的律师咨询方式存在信息不透明、咨......
  • 财务管理系统【附源码】
    项目简介前面所做的功能分析,只是本系统的一个大概功能,这部分需要在此基础上进行各个模块的详细设计。设计的管理员的详细功能见下图,管理员登录进入本人后台之后,管理职工和部门,管理企业资产,经营信息和职工薪资。设计的职工的详细功能见下图,职工查询和查看企业经营和企业资......
  • SSM旅游信息管理系统
    ......
  • springboot毕设 基于Springboot的养老院管理系统 程序+论文
    本系统(程序+源码)带文档lw万字以上文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着社会的老龄化进程加速,养老院作为老年人生活照顾和健康管理的重要场所,其管理和运营效率直接关系到老年人的生活质量与幸福感。近年来,我国养老院数......
  • springboot毕设 基于springboot的校园招聘管理系统 程序+论文
    本系统(程序+源码)带文档lw万字以上文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着高等教育的普及和就业市场的日益竞争激烈,校园招聘已成为连接企业与学生的重要桥梁。然而,传统的校园招聘方式往往面临信息不对称、流程繁琐、效率......
  • 基于SSM的高校时间管理系统【附源码+文档】
    ......