热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

通讯录管理_通讯录管理系统

篇首语:本文由编程笔记#小编为大家整理,主要介绍了通讯录管理系统相关的知识,希望对你有一定的参考价值。?详情请关注微信公众号:“晚风花间寺中人”-后端学习-项目管

篇首语:本文由编程笔记#小编为大家整理,主要介绍了通讯录管理系统相关的知识,希望对你有一定的参考价值。


?
详情请关注微信公众号:“晚风花间寺中人”-后端学习-项目管理
1、系统需求
通讯录是一个可以记录亲人、好友信息的工具。

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

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

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

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

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

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

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

清空联系人:清空通讯录中所有信息

退出通讯录:退出当前使用的通讯录

2、创建项目
创建项目步骤如下:

创建新项目

添加文件


2.1 创建项目

打开vs后,点击创建新项目,创建新的C++项目

填写项目名称,选择项目路径

2.2添加文件
添加新建项

至此,项目已创建完毕

3、菜单功能
功能描述: 用户选择功能的界面

菜单界面效果如下图:

步骤:

封装函数显示该界面 如 void showMenu()

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

代码:


include

using namespace std;

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

int main() {

showMenu();

system("pause");

return 0;
}
4、退出功能
功能描述:退出通讯录系统

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

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

代码:

int main() {

int select = 0;

while (true)
{
showMenu();

cin >> select;

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

system("pause");

return 0;
}
5、添加联系人
功能描述:

实现添加联系人功能,联系人上限为1000人,联系人信息包括(姓名、性别、年龄、联系电话、家庭住址)

添加联系人实现步骤:

设计联系人结构体

设计通讯录结构体

main函数中创建通讯录

封装添加联系人函数

测试添加联系人功能

5.1 设计联系人结构体
联系人信息包括:姓名、性别、年龄、联系电话、家庭住址

设计如下:


include //string头文件

//联系人结构体
struct Person
{
string m_Name; //姓名
int m_Sex; //性别:1男 2女
int m_Age; //年龄
string m_Phone; //电话
string m_Addr; //住址
};

5.2 设计通讯录结构体
设计时候可以在通讯录结构体中,维护一个容量为1000的存放联系人的数组,并记录当前通讯录中联系人数量

设计如下


define MAX 1000 //最大人数

//通讯录结构体
struct Addressbooks
{
struct Person personArray[MAX]; //通讯录中保存的联系人数组
int m_Size; //通讯录中人员个数
};

5.3 main函数中创建通讯录

添加联系人函数封装好后,在main函数中创建一个通讯录变量,这个就是我们需要一直维护的通讯录

mian函数起始位置添加:

//创建通讯录
Addressbooks abs;
//初始化通讯录中人数
abs.m_Size = 0;

5.4 封装添加联系人函数

思路:添加联系人前先判断通讯录是否已满,如果满了就不再添加,未满情况将新联系人信息逐个加入到通讯录

添加联系人代码:

//1、添加联系人信息
void addPerson(Addressbooks *abs)
{
//判断电话本是否满了
if (abs->m_Size == MAX)
{
cout <<"通讯录已满,无法添加" <return;
}
else
{
//姓名
string name;
cout <<"请输入姓名:" <cin >> name;
abs->personArray[abs->m_Size].m_Name = name;

cout <<"请输入性别:" <cout <<"1 -- 男" <cout <<"2 -- 女" <

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

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

//联系电话
cout <<"请输入联系电话:" <string phOne= "";
cin >> phone;
abs->personArray[abs->m_Size].m_PhOne= phone;

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

//更新通讯录人数
abs->m_Size++;

cout <<"添加成功" <system("pause");
system("cls");
}
}
5.5 测试添加联系人功能
选择界面中,如果玩家选择了1,代表添加联系人,我们可以测试下该功能

在switch case 语句中,case1里添加:

case 1: //添加联系人
addPerson(&abs);
break;

6、显示联系人
功能描述:显示通讯录中已有的联系人信息

显示联系人实现步骤:

封装显示联系人函数

测试显示联系人功能

6.1 封装显示联系人函数

思路:判断如果当前通讯录中没有人员,就提示记录为空,人数大于0,显示通讯录中信息

显示联系人代码:

//2、显示所有联系人信息
void showPerson(Addressbooks * abs)
{
if (abs->m_Size == 0)
{
cout <<"当前记录为空" <}
else
{
for (int i = 0; i m_Size; i++)
{
cout <<"姓名:" <personArray[i].m_Name <<" ";
cout <<"性别:" <<(abs->personArray[i].m_Sex == 1 ? "男" : "女") <<" ";
cout <<"年龄:" <personArray[i].m_Age <<" ";
cout <<"电话:" <personArray[i].m_Phone <<" ";
cout <<"住址:" <personArray[i].m_Addr <}
}

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

}

6.2 测试显示联系人功能

在switch case语句中,case 2 里添加

case 2: //显示联系人
showPerson(&abs);
break;

7、删除联系人
功能描述:按照姓名进行删除指定联系人

删除联系人实现步骤:

封装检测联系人是否存在

封装删除联系人函数

测试删除联系人功能

7.1 封装检测联系人是否存在
设计思路:

删除联系人前,我们需要先判断用户输入的联系人是否存在,如果存在删除,不存在提示用户没有要删除的联系人

因此我们可以把检测联系人是否存在封装成一个函数中,如果存在,返回联系人在通讯录中的位置,不存在返回-1

检测联系人是否存在代码:

//判断是否存在查询的人员,存在返回在数组中索引位置,不存在返回-1
int isExist(Addressbooks * abs, string name)
{
for (int i = 0; i m_Size; i++)
{
if (abs->personArray[i].m_Name == name)
{
return i;
}
}
return -1;
}

7.2 封装删除联系人函数

根据用户输入的联系人判断该通讯录中是否有此人

查找到进行删除,并提示删除成功

查不到提示查无此人。

//3、删除指定联系人信息
void deletePerson(Addressbooks * abs)
{
cout <<"请输入您要删除的联系人" <string name;
cin >> name;

int ret = isExist(abs, name);
if (ret != -1)
{
for (int i = ret; i m_Size; i++)
{
abs->personArray[i] = abs->personArray[i + 1];
}
abs->m_Size--;
cout <<"删除成功" <}
else
{
cout <<"查无此人" <}

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

7.3 测试删除联系人功能
在switch case 语句中,case3里添加:

case 3: //删除联系人
deletePerson(&abs);
break;
8、查找联系人

功能描述:按照姓名查看指定联系人信息

查找联系人实现步骤

封装查找联系人函数

测试查找指定联系人

8.1 封装查找联系人函数
实现思路:判断用户指定的联系人是否存在,如果存在显示信息,不存在则提示查无此人。

查找联系人代码:

//4、查找指定联系人信息
void findPerson(Addressbooks * abs)
{
cout <<"请输入您要查找的联系人" <string name;
cin >> name;

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

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

}
8.2 测试查找指定联系人
在switch case 语句中,case4里添加:

case 4: //查找联系人
findPerson(&abs);
break;
9、修改联系人

功能描述:按照姓名重新修改指定联系人

修改联系人实现步骤

封装修改联系人函数

测试修改联系人功能

9.1 封装修改联系人函数
实现思路:查找用户输入的联系人,如果查找成功进行修改操作,查找失败提示查无此人

修改联系人代码:

//5、修改指定联系人信息
void modifyPerson(Addressbooks * abs)
{
cout <<"请输入您要修改的联系人" <string name;
cin >> name;

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

cout <<"请输入性别:" <cout <<"1 -- 男" <cout <<"2 -- 女" <

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

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

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

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

cout <<"修改成功" <}
else
{
cout <<"查无此人" <}

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

}
9.2 测试修改联系人功能
在switch case 语句中,case 5里添加:

case 5: //修改联系人
modifyPerson(&abs);
break;

10、清空联系人

功能描述:清空通讯录中所有信息

清空联系人实现步骤

封装清空联系人函数

测试清空联系人

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

清空联系人代码:

//6、清空所有联系人
void cleanPerson(Addressbooks * abs)
{
abs->m_Size = 0;
cout <<"通讯录已清空" <system("pause");
system("cls");
}
10.2 测试清空联系人
在switch case 语句中,case 6 里添加:

case 6: //清空联系人
cleanPerson(&abs);
break;
至此,通讯录管理系统完成!

11、最终代码


include

using namespace std;


include //string头文件

//联系人结构体
struct Person
{
string m_Name; //姓名
int m_Sex; //性别:1男 2女
int m_Age; //年龄
string m_Phone; //电话
string m_Addr; //住址
};


define MAX 1000 //最大人数

//通讯录结构体
struct Addressbooks
{
struct Person personArray[MAX]; //通讯录中保存的联系人数组
int m_Size; //通讯录中人员个数
};
//1、添加联系人信息
void addPerson(Addressbooks* abs)
{
//判断电话本是否满了
if (abs->m_Size == MAX)
{
cout <<"通讯录已满,无法添加" <return;
}
else
{
//姓名
string name;
cout <<"请输入姓名:" <cin >> name;
abs->personArray[abs->m_Size].m_Name = name;

cout <<"请输入性别:" <cout <<"1 -- 男" <cout <<"2 -- 女" <

//性别
int sex = 0;
while (true)
{
cin >> sex;
//如果输入1或者2可以退出循环,因为输入的是正确值
if (sex == 1 || sex == 2) //逻辑运算符-或
{
abs->personArray[abs->m_Size].m_Sex = sex;
break;
}
cout <<"输入有误,请重新输入";
}

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

//联系电话
cout <<"请输入联系电话:" <string phOne= "";
cin >> phone;
abs->personArray[abs->m_Size].m_PhOne= phone;

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

//更新通讯录人数
abs->m_Size++;

cout <<"添加成功" <system("pause"); //请按任意键继续
system("cls");//清屏操作
}
}
//2、显示所有联系人信息
void showPerson(Addressbooks* abs)
{
if (abs->m_Size == 0)
{
cout <<"当前记录为空" <}
else
{
for (int i = 0; i m_Size; i++)
{
cout <<"姓名:" <personArray[i].m_Name <<" ";
cout <<"性别:" <<(abs->personArray[i].m_Sex == 1 ? "男" : "女") <<" ";
cout <<"年龄:" <personArray[i].m_Age <<" ";
cout <<"电话:" <personArray[i].m_Phone <<" ";
cout <<"住址:" <personArray[i].m_Addr <}
}

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

}
//判断是否存在查询的人员,存在返回在数组中索引位置,不存在返回-1
//参数1 通讯录 参数2 对比姓名
int isExist(Addressbooks* abs, string name)
{
for (int i = 0; i m_Size; i++)
{
//找到用户的姓名了
if (abs->personArray[i].m_Name == name)
{
return i; //返回
}
}
return -1;
}
//3、删除指定联系人信息
void deletePerson(Addressbooks* abs)
{
cout <<"请输入您要删除的联系人" <string name;
cin >> name;
// ret == -1 未查到
// ret !== -1 查到

int ret = isExist(abs, name);
if (ret != -1)
{
for (int i = ret; i m_Size; i++)
{
abs->personArray[i] = abs->personArray[i + 1];//覆盖上一个数组下标
}
abs->m_Size--;//更新通讯录人员数
cout <<"删除成功" <}
else
{
cout <<"查无此人" <}

system("pause");
system("cls");
}
//4、查找指定联系人信息
void findPerson(Addressbooks* abs)
{
cout <<"请输入您要查找的联系人" <string name;
cin >> name;

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

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

}
//5、修改指定联系人信息
void modifyPerson(Addressbooks* abs)
{
cout <<"请输入您要修改的联系人" <string name;
cin >> name;

int ret = isExist(abs, name);
if (ret != -1)//找到指定联系人
{
//姓名
string name;
cout <<"请输入姓名:" <cin >> name;
abs->personArray[ret].m_Name = name;

cout <<"请输入性别:" <cout <<"1 -- 男" <cout <<"2 -- 女" <

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

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

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

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

cout <<"修改成功" <}
else
{
cout <<"查无此人" <}

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

}
//6、清空所有联系人
//实现思路:将通讯录所有联系人信息清除掉,只要将通讯录记录的联系人数量置为0,做逻辑清空即可。
void cleanPerson(Addressbooks* abs)
{
abs->m_Size = 0;
cout <<"通讯录已清空" <system("pause");
system("cls");
}
//菜单界面
void showMenu()
{
cout <<"" <cout <<" 1、添加联系人 " <cout <<" 2、显示联系人 " <cout <<" 3、删除联系人 " <cout <<" 4、查找联系人 " <cout <<" 5、修改联系人 " <cout <<" 6、清空联系人 " <cout <<" 0、退出通讯录 " <cout <<"" <}

int main() {
//创建通讯录
Addressbooks abs;
//初始化通讯录中人数
abs.m_Size = 0;

int select = 0;

while (true)
{
showMenu();
cout <<"请选择菜单序号:" <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 <<"欢迎下次使用" <system("pause");
return 0;
break;
default:
break;
}
}

system("pause");

return 0;
}


推荐阅读
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 本文介绍了解决二叉树层序创建问题的方法。通过使用队列结构体和二叉树结构体,实现了入队和出队操作,并提供了判断队列是否为空的函数。详细介绍了解决该问题的步骤和流程。 ... [详细]
  • 本文讨论了clone的fork与pthread_create创建线程的不同之处。进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合。在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性。但是二者之间的通讯需要通过专门的通讯机制,另外通过fork创建子进程系统开销很大。因此,在某些情况下,使用clone或pthread_create创建线程可能更加高效。 ... [详细]
  • 开发笔记:实验7的文件读写操作
    本文介绍了使用C++的ofstream和ifstream类进行文件读写操作的方法,包括创建文件、写入文件和读取文件的过程。同时还介绍了如何判断文件是否成功打开和关闭文件的方法。通过本文的学习,读者可以了解如何在C++中进行文件读写操作。 ... [详细]
  • Go语言实现堆排序的详细教程
    本文主要介绍了Go语言实现堆排序的详细教程,包括大根堆的定义和完全二叉树的概念。通过图解和算法描述,详细介绍了堆排序的实现过程。堆排序是一种效率很高的排序算法,时间复杂度为O(nlgn)。阅读本文大约需要15分钟。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • LeetCode笔记:剑指Offer 41. 数据流中的中位数(Java、堆、优先队列、知识点)
    本文介绍了LeetCode剑指Offer 41题的解题思路和代码实现,主要涉及了Java中的优先队列和堆排序的知识点。优先队列是Queue接口的实现,可以对其中的元素进行排序,采用小顶堆的方式进行排序。本文还介绍了Java中queue的offer、poll、add、remove、element、peek等方法的区别和用法。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • Android源码深入理解JNI技术的概述和应用
    本文介绍了Android源码中的JNI技术,包括概述和应用。JNI是Java Native Interface的缩写,是一种技术,可以实现Java程序调用Native语言写的函数,以及Native程序调用Java层的函数。在Android平台上,JNI充当了连接Java世界和Native世界的桥梁。本文通过分析Android源码中的相关文件和位置,深入探讨了JNI技术在Android开发中的重要性和应用场景。 ... [详细]
author-avatar
DHY微学院朱曜宇
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有