C++——通讯录管理系统

C++——通讯录管理系统,第1张

文章目录
  • 前言
  • 一、系统中需要实现的功能
    • 1、添加联系人
    • 2、显示联系人
    • 3、删除联系人
    • 4、查找联系人
    • 5、修改联系人
    • 6、清空联系人
    • 7、退出通讯录
  • 二、创建项目
    • 1、创建新项目
    • 2、添加文件
  • 三、菜单功能
    • 1、功能描述
    • 2、步骤
      • 2.1、封装函数显示该界面
      • 2.2、在main函数中调用封装好的函数
  • 四、退出功能
    • 1、功能描述
    • 2、思路
    • 3、代码实现
  • 五、添加联系人功能
    • 1、功能描述
    • 2、步骤
      • 2.1、设计联系人结构体
      • 2.2、设计通讯录结构体
      • 2.3、main函数中创建通讯录
      • 2.4、封装添加联系人函数
      • 2.5、测试添加联系人函数
  • 六、显示联系人
    • 1、功能
    • 2、步骤
      • 2.1、封装显示联系人函数
      • 2.2、测试显示联系人函数
  • 七、删除联系人
    • 1、功能
    • 2、步骤
      • 2.1、封装检测联系人是否存在
      • 2.2、封装删除联系人函数
      • 2.3、测试删除联系人函数
  • 八、查找联系人
    • 1、功能
    • 2、步骤
      • 2.1、封装查找联系人的函数
      • 2.2、测试查找联系人的函数
  • 九、修改联系人
    • 1、功能
    • 2、步骤
      • 2.1、封装修改联系人的函数
      • 2.2、测试修改联系人的函数
  • 十、清空联系人
    • 1、功能
    • 2、步骤
      • 2.1、封装清空联系人的函数
      • 2.2、测试清空联系人的函数
  • 附:完整代码
    • 至此通讯录管理系统完成
      • 本系统只是简单的实现通讯录管理,还有很多细节并没有做,比如年龄的范围判断等,还有就是每次运行程序通讯录都被清空了,不会保存,这点本人目前还不会做,后面学习了相关的知识再加上!


前言

通讯录是一个可以记录亲人、好友信息的工具。


本文主要利用C++来实现一个通讯录管理系统

一、系统中需要实现的功能 1、添加联系人

向通讯录中添加新人,信息包括(姓名、性别、年龄、联系电话、家庭住址)最多记录1000人

2、显示联系人

显示通讯录中所有联系人信息

3、删除联系人

按照姓名进行删除指定联系人

4、查找联系人

按照姓名查看指定联系人信息

5、修改联系人

按照姓名重新修改指定联系人

6、清空联系人

清空通讯录中所有信息

7、退出通讯录

退出当前使用的通讯录


二、创建项目 1、创建新项目

2、添加文件


三、菜单功能 1、功能描述

用户选择功能的界面

2、步骤 2.1、封装函数显示该界面

2.2、在main函数中调用封装好的函数
#include
#include

using namespace std;

//菜单界面
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;
}
int main()
{
	//菜单的调用
	showMenu();

	system("pause");
	return 0;
}

结果显示:


四、退出功能 1、功能描述

退出通讯录系统

2、思路

根据用户不同的选择,进入不同的功能,可以选择switch分支结构,将整个架构进行搭建。

当用户选择0时候,执行退出,选择其他先不做 *** 作,也不会退出程序。

3、代码实现
    //创建用户选择输入的变量
	int select = 0; 
	while (1)
	{
		//菜单的调用
		showMenu();

		cin >> select;
		switch (select)
		{
		case 1:  //1、添加联系人
			break;
		case 2:  //2、显示联系人
			break;
		case 3:  //3、删除联系人
			break;
		case 4:  //4、查找联系人
			break;
		case 5:  //5、修改联系人
			break;
		case 6:  //6、清空联系人
			break;
		case 0:  //0、退出通讯录
			cout << "欢迎下次使用" << endl;
			system("pause");
			return 0;
			break;
		}
	}


五、添加联系人功能 1、功能描述

实现添加联系人功能,向通讯录中添加新人,信息包括(姓名、性别、年龄、联系电话、家庭住址),最多记录1000人

2、步骤 2.1、设计联系人结构体
struct Person
{
	string m_Name;
	int m_Sex;  //性别,1-男  2-女
	int m_Age;
	string m_Phone;
	string m_Addr;

};
2.2、设计通讯录结构体
#define MAX 1000  //最大值
//通讯录结构体
struct AddressBooks
{
	struct Person personArray[MAX]; //通讯录保存的联系人数组
	int m_size;  //通讯录人员个数
};
2.3、main函数中创建通讯录
//创建通讯录
	struct AddressBooks abs;
	abs.m_size = 0;
2.4、封装添加联系人函数
void addPerson(struct 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;
		//性别
		int sex = 0;
		cout << "请输入性别:1-男生 2-女生" << endl;
		cout << "1-男生" << endl;
		cout << "2-女生" << endl;
		
		while (1)
		{
			//输入1、2可退出循环,其余的则重新输入
			cin >> sex;
			if (sex == 1 || sex == 2)
			{
				abs->personArray[abs->m_size].m_Sex = sex;
				break;
			}
			cout << "输入有误,请重新输入!" << endl;
		}
		
		//年龄
		int age;
		cout << "请输入年龄:" << endl;
		cin >> age;
		abs->personArray[abs->m_size].m_Age = age;
		//电话
		string Phone;
		cout << "请输入联系电话:" << endl;
		cin >> Phone;
		abs->personArray[abs->m_size].m_Phone = Phone;
		//家庭住址
		string Address;
		cout << "请输入家庭住址:" << endl;
		cin >> Address;
		abs->personArray[abs->m_size].m_Addr= Address;
		//更新人数
		abs->m_size++;
		cout << "添加成功!" << endl;

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

	}
}
2.5、测试添加联系人函数
case 1:  //1、添加联系人
			addPerson(&abs);
			break;


六、显示联系人 1、功能

显示通讯录中已有联系人的信息

2、步骤 2.1、封装显示联系人函数
void showPerson(struct AddressBooks * abs)
{
	//判断通讯录中人数是否为0,为0,提示记录为空
	//如果不为0,则显示联系人的信息
	if (abs->m_size == 0)
	{
		cout << "当前通讯录为空!" << endl;
	}
	else
	{
		for (int i = 0; i < abs->m_size; i++)
		{
			cout << "姓名:" << abs->personArray[i].m_Name << "\t"
				 << "性别:" << (abs->personArray[i].m_Sex == 1 ? "男" : "女") << "\t"
				 << "年龄:" << abs->personArray[i].m_Age << "\t"
				 << "电话:" << abs->personArray[i].m_Phone << "\t"
				 << "家庭住址:" << abs->personArray[i].m_Addr << endl;
		}
	}

	system("pause");
	system("cls");
}
2.2、测试显示联系人函数
case 2:  //2、显示联系人
			showPerson(&abs);
			break;


七、删除联系人 1、功能

按照姓名进行删除指定联系人

2、步骤 2.1、封装检测联系人是否存在
int isExist(struct AddressBooks * abs, string name)
{
	for (int i = 0; i < abs->m_size; i++)
	{
		if (abs->personArray[i].m_Name == name)
		{
			return i;//找到了,返回编号
		}
	}
	return -1; //如果遍历完都没有找到,返回-1
}
2.2、封装删除联系人函数
void deletePerson(struct 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");
}
2.3、测试删除联系人函数



八、查找联系人 1、功能

按照姓名查看指定联系人的信息

2、步骤 2.1、封装查找联系人的函数
void findPerson(struct AddressBooks * abs)
{
	cout << "请输入您要查找的联系人:" << endl;
	string name;
	cin >> name;
	//判断指定的联系人是否在通讯录中
	int ret = isExist(abs, name);
	if (ret != -1) //找到联系人
	{
		cout << "姓名:" << abs->personArray[ret].m_Name << "\t"
			 << "性别:" << (abs->personArray[ret].m_Sex == 1 ? "男" : "女") << "\t"
			 << "年龄:" << abs->personArray[ret].m_Age << "\t"
			 << "电话:" << abs->personArray[ret].m_Phone << "\t"
			 << "家庭住址:" << abs->personArray[ret].m_Addr << endl;
	}
	else //未找到联系人
	{
		cout << "查无此人!" << endl;
	}

	system("pause");
	system("cls");
}
2.2、测试查找联系人的函数


九、修改联系人 1、功能

按照姓名重新修改指定联系人的信息

2、步骤 2.1、封装修改联系人的函数
void modifyPerson(struct 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;
		//性别
		int sex = 0;
		cout << "请输入修改后的性别:1-男生 2-女生" << endl;
		cout << "1-男生" << endl;
		cout << "2-女生" << endl;

		while (1)
		{
			//输入1、2可退出循环,其余的则重新输入
			cin >> sex;
			if (sex == 1 || sex == 2)
			{
				abs->personArray[ret].m_Sex = sex;
				break;
			}
			cout << "输入有误,请重新输入!" << endl;
		}

		//年龄
		int age;
		cout << "请输入修改后的年龄:" << endl;
		cin >> age;
		abs->personArray[ret].m_Age = age;
		//电话
		string Phone;
		cout << "请输入修改后的联系电话:" << endl;
		cin >> Phone;
		abs->personArray[ret].m_Phone = Phone;
		//家庭住址
		string Address;
		cout << "请输入修改后的家庭住址:" << endl;
		cin >> Address;
		abs->personArray[ret].m_Addr = Address;
		cout << "修改成功!" << endl;
	}
	else //未找到联系人
	{
		cout << "查无此人!" << endl;
	}

	system("pause");
	system("cls");
}
2.2、测试修改联系人的函数

修改前

修改过程

修改后


十、清空联系人 1、功能

清空所有联系人的信息

2、步骤 2.1、封装清空联系人的函数

实现思路:将通界录所有联系人信息清除掉,只要将通讯录记录的联系人数量置为0,做逻辑清空即可。

void cleanPerson(struct AddressBooks * abs)
{
	cout << "请问您是否真的要清空通讯录?" << endl;
	cout << "1-是" << endl;
	cout << "2-否" << endl;
	int ret = 0;
	cin >> ret;
	if (ret == 1)
	{
		abs->m_size = 0;
		cout << "通讯录已清空!" << endl;
	}

	system("pause");
	system("cls");
}
2.2、测试清空联系人的函数

清空前

清空 *** 作:程序会让用户确认下是否真的要清空。

清空后


附:完整代码
#include
#include

using namespace std;
#define MAX 1000  //最大值
//联系人结构体
struct Person
{
	string m_Name;
	int m_Sex;  //性别,1-男  2-女
	int m_Age;
	string m_Phone;
	string m_Addr;

};
//通讯录结构体
struct AddressBooks
{
	struct Person personArray[MAX]; //通讯录保存的联系人数组
	int m_size;  //通讯录人员个数
};
//1、添加联系人
void addPerson(struct 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;
		//性别
		int sex = 0;
		cout << "请输入性别:1-男生 2-女生" << endl;
		cout << "1-男生" << endl;
		cout << "2-女生" << endl;
		
		while (1)
		{
			//输入1、2可退出循环,其余的则重新输入
			cin >> sex;
			if (sex == 1 || sex == 2)
			{
				abs->personArray[abs->m_size].m_Sex = sex;
				break;
			}
			cout << "输入有误,请重新输入!" << endl;
		}
		
		//年龄
		int age;
		cout << "请输入年龄:" << endl;
		cin >> age;
		abs->personArray[abs->m_size].m_Age = age;
		//电话
		string Phone;
		cout << "请输入联系电话:" << endl;
		cin >> Phone;
		abs->personArray[abs->m_size].m_Phone = Phone;
		//家庭住址
		string Address;
		cout << "请输入家庭住址:" << endl;
		cin >> Address;
		abs->personArray[abs->m_size].m_Addr= Address;
		//更新人数
		abs->m_size++;
		cout << "添加成功!" << endl;

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

	}
}
//2、显示联系人
void showPerson(struct AddressBooks * abs)
{
	//判断通讯录中人数是否为0,为0,提示记录为空
	//如果不为0,则显示联系人的信息
	if (abs->m_size == 0)
	{
		cout << "当前通讯录为空!" << endl;
	}
	else
	{
		for (int i = 0; i < abs->m_size; i++)
		{
			cout << "姓名:" << abs->personArray[i].m_Name << "\t"
				 << "性别:" << (abs->personArray[i].m_Sex == 1 ? "男" : "女") << "\t"
				 << "年龄:" << abs->personArray[i].m_Age << "\t"
				 << "电话:" << abs->personArray[i].m_Phone << "\t"
				 << "家庭住址:" << abs->personArray[i].m_Addr << endl;
		}
	}

	system("pause");
	system("cls");
}
//检测联系人是否存在,如果存在,返回联系人所在数组中的具体位置,不存在返回-1
int isExist(struct AddressBooks * abs, string name)
{
	for (int i = 0; i < abs->m_size; i++)
	{
		if (abs->personArray[i].m_Name == name)
		{
			return i;//找到了,返回编号
		}
	}
	return -1; //如果遍历完都没有找到,返回-1
}
//3、删除指定的联系人
void deletePerson(struct 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");
}
//4、查找指定的联系人
void findPerson(struct AddressBooks * abs)
{
	cout << "请输入您要查找的联系人:" << endl;
	string name;
	cin >> name;
	//判断指定的联系人是否在通讯录中
	int ret = isExist(abs, name);
	if (ret != -1) //找到联系人
	{
		cout << "姓名:" << abs->personArray[ret].m_Name << "\t"
			 << "性别:" << (abs->personArray[ret].m_Sex == 1 ? "男" : "女") << "\t"
			 << "年龄:" << abs->personArray[ret].m_Age << "\t"
			 << "电话:" << abs->personArray[ret].m_Phone << "\t"
			 << "家庭住址:" << abs->personArray[ret].m_Addr << endl;
	}
	else //未找到联系人
	{
		cout << "查无此人!" << endl;
	}

	system("pause");
	system("cls");
}
//5、修改指定的联系人
void modifyPerson(struct 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;
		//性别
		int sex = 0;
		cout << "请输入修改后的性别:1-男生 2-女生" << endl;
		cout << "1-男生" << endl;
		cout << "2-女生" << endl;

		while (1)
		{
			//输入1、2可退出循环,其余的则重新输入
			cin >> sex;
			if (sex == 1 || sex == 2)
			{
				abs->personArray[ret].m_Sex = sex;
				break;
			}
			cout << "输入有误,请重新输入!" << endl;
		}

		//年龄
		int age;
		cout << "请输入修改后的年龄:" << endl;
		cin >> age;
		abs->personArray[ret].m_Age = age;
		//电话
		string Phone;
		cout << "请输入修改后的联系电话:" << endl;
		cin >> Phone;
		abs->personArray[ret].m_Phone = Phone;
		//家庭住址
		string Address;
		cout << "请输入修改后的家庭住址:" << endl;
		cin >> Address;
		abs->personArray[ret].m_Addr = Address;
		cout << "修改成功!" << endl;
	}
	else //未找到联系人
	{
		cout << "查无此人!" << endl;
	}

	system("pause");
	system("cls");
}
//6、清空联系人
void cleanPerson(struct AddressBooks * abs)
{
	cout << "请问您是否真的要清空通讯录?" << endl;
	cout << "1-是" << endl;
	cout << "2-否" << endl;
	int ret = 0;
	cin >> ret;
	if (ret == 1)
	{
		abs->m_size = 0;
		cout << "通讯录已清空!" << endl;
	}

	system("pause");
	system("cls");
}
//菜单界面
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;
}

int main()
{
	//创建用户选择输入的变量
	int select = 0; 
	//创建通讯录
	struct AddressBooks abs;
	abs.m_size = 0;
	while (1)
	{
		//菜单的调用
		showMenu();

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

	system("pause");
	return 0;
}

至此通讯录管理系统完成 本系统只是简单的实现通讯录管理,还有很多细节并没有做,比如年龄的范围判断等,还有就是每次运行程序通讯录都被清空了,不会保存,这点本人目前还不会做,后面学习了相关的知识再加上!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/674033.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-04-19
下一篇2022-04-19

发表评论

登录后才能评论

评论列表(0条)

    保存