0
点赞
收藏
分享

微信扫一扫

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

伊人幽梦 2022-04-16 阅读 55
c++

文章目录


前言

通讯录是一个可以记录亲人、好友信息的工具。
本文主要利用C++来实现一个通讯录管理系统

一、系统中需要实现的功能

1、添加联系人

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

2、显示联系人

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

3、删除联系人

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

4、查找联系人

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

5、修改联系人

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

6、清空联系人

清空通讯录中所有信息

7、退出通讯录

退出当前使用的通讯录


二、创建项目

1、创建新项目

在这里插入图片描述

2、添加文件

在这里插入图片描述


三、菜单功能

1、功能描述

用户选择功能的界面

2、步骤

2.1、封装函数显示该界面

void showMenu()

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

#include<iostream>
#include<string>

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,做逻辑清空即可。

2.2、测试清空联系人的函数

清空前
在这里插入图片描述
清空操作:程序会让用户确认下是否真的要清空。

在这里插入图片描述

清空后
在这里插入图片描述


至此通讯录管理系统完成

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

举报

相关推荐

0 条评论