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

通讯录管理系统

写在最前面:(给自己的一个小falg)在6月开始之前,将这个程序分文件编写清屏操作:在这个问题的程序中,清屏操作在每个分装的函数里面system(pause);请按任意键继续



写在最前面:(给自己的一个小falg)
在6月开始之前,将这个程序分文件编写

清屏操作:
在这个问题的程序中,清屏操作在每个分装的函数里面

system("pause"); //请按任意键继续
system("cls"); //清屏

程序整体代码

/*---------------------------------------------------------------------------------------------
1.菜单功能
- 封装函数显示该界面,如void showMenu()
- 在main函数中调用封装好的函数
2.退出功能
- 根据用户不同的选择,进入不同的功能,可以选择switch分支结构,将整个架构进行搭建
- 当用户选择0时候,执行退出,选择其他先不做操作,也不会退出程序
3.添加联系人功能
- 实现添加联系人功能,联系人上限为1000人,联系人信息包括(姓名、性别、年龄、联系电话、家庭地址)
- 实现步骤:
1.设计联系人结构体
2.设计通讯录结构体
3.main函数中创建通讯录
4.封装添加联系人函数
5.测试添加联系人功能
4.显示联系人
- 显示通讯录中已有联系人信息
- 实现步骤:
1.封装显示联系人函数
思路:判断如果当前通讯录中没有人员,就显示为空;人数大于0,显示通讯录中信息
2.测试显示联系人函数
5.删除联系人
- 按照姓名进行删除指定联系人
- 实现步骤:
1.封装检测联系人是否存在
2.封装删除联系人函数
3.测试删除联系人功能
- 思路:删除联系人前,我们需要判断用户输入的联系人是否存在,如果存在删除,不存在提示用户没有要删除的联系人
因此我们可以把检测联系人是否存在封装成一个函数,如果存在,返回联系人在通讯录中的位置,不存在返回 - 1
6.查找联系人
- 实现步骤:
1.封装查找联系人函数
2.测试查找指定联系人
- 思路:判断用户指定的联系人是否存在,如果存在显示信息,不存在则提示查无此人
7.修改联系人
- 按照姓名重新修改指定联系人
- 实现步骤:
1.封装修改联系人函数
2.测试修改联系人函数
- 思路:查找用户输入的联系人,如果查找成功进行修改操作,查找失败提示查无此人
8.清空联系人
- 实现步骤:
1.封装清空联系人函数
2.测试清空联系人
- 思路:将通讯录所有联系人信息清除掉,只要将通讯录记录的联系人数量置为0,做逻辑清空即可
---------------------------------------------------------------------------------------------------*/
#include
#include
#define MAX 1000 //通讯录联系人数最多1000人
using namespace std;
//设计联系人结构体(姓名、性别、年龄、联系电话、家庭地址)
struct Person {
//姓名
string m_Name;
//性别
int m_Gender;
//年龄
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 <<"通讯录已满,无法添加" < }
else {//添加具体联系人
//添加姓名
string name;
cout <<"请输入您的姓名:" < cin >> name;
abs->personArray[abs->m_Size].m_Name = name;
//添加性别
int gender;
cout <<"请输入您的性别:(1表示男,0表示女)" < while (true)
{
cin >> gender;
if (gender == 1 || gender == 0)
{
abs->personArray[abs->m_Size].m_Gender = gender;
break;
}else{
cout <<"您输入的性别有误,请重新输入!" < }
}
//添加年龄
int age;
cout <<"请输入您的年龄(0-150):" < while (true)
{
cin >> age;
if (age <= 150 && age >= 0)
{
abs->personArray[abs->m_Size].m_Age = age;
break;
}
else
{
cout <<"您输入的年龄不符合实际,请重新输入!" < cout <<"请输入您的年龄(0-150):" < }
}
//添加联系电话
string phoneNumber;
cout <<"请输入您的11位电话号码" < cin >> phoneNumber;
abs->personArray[abs->m_Size].m_PhOne= phoneNumber;
//添加家庭住址
string addressHome;
cout <<"请输入您的家庭住址:" < cin >> addressHome;
abs->personArray[abs->m_Size].m_Addr = addressHome;
//更新通讯录中联系人数+1
abs->m_Size++;
cout <<"成功添加!" < system("pause"); //请按任意键继续
system("cls"); //清屏
}
}
//2.显示联系人
void showPerson(struct Addressbooks* abs)
{
//判断通讯录中人数是否为0,如果为0,提示记录为空
//如果人数大于0,显示记录的联系人信息
if (abs->m_Size == 0)
{
cout <<"记录为空,请添加联系人!" < }else{
for (int i = 0; i m_Size; i++)
{
cout <<"第" < cout <<" 姓名:" <personArray[i].m_Name <<'\t';
cout <<" 性别:" <<(abs->personArray[i].m_Gender == 1 ? "男" : "女") <<'\t';
cout <<" 年龄:" <personArray[i].m_Age <<'\t';
cout <<" 联系电话:" <personArray[i].m_Phone <<'\t';
cout <<" 家庭住址:" <personArray[i].m_Addr < }
}
system("pause"); //请按任意键继续
system("cls"); //清屏
}
//检测联系人是否存在,如果存在,返回联系人在数组中的下标位置,不存在返回-1
int isExist(struct Addressbooks* abs, string name)//参数1传通讯录,参数2传需要检测的人名
{
for (int i = 0; i m_Size; i++)
{
if (abs->personArray[i].m_Name == name)
{
//找到了,返回下标位置
return i;
}
}
return -1;
}
//3.联系人确实存在,删除联系人
void deletePerson(struct Addressbooks* abs)
{
cout <<"请输入您需要删除的联系人的姓名:" < string name;
cin >> name;
int ret = isExist(abs, name);
if (ret == -1){
cout <<"查无此人" < }else{
//将数组中后面的数据覆盖前面的数据,实现删除
for (int i = ret; i m_Size; i++)
{
//数据前移
abs->personArray[i] = abs->personArray[i + 1];
}
//通讯录中的联系人数-1
abs->m_Size--;
cout <<"删除成功" < }
system("pause"); //请按任意键继续
system("cls"); //清屏
}
//4.查找指定联系人信息
void findPerson(struct Addressbooks* abs)
{
cout <<"请输入要查找的联系人姓名:" < string name;
cin >> name;
//判断指定的联系人是否存在通讯录中
int ret = isExist(abs, name);
if (ret == -1){
cout <<"查无此人" < }else{
cout <<"姓名:" <personArray[ret].m_Name <<'\t'
<<" 性别:" <<(abs->personArray[ret].m_Gender == 1? "男" : "女" )<<'\t'
<<" 年龄:" <personArray[ret].m_Age <<'\t'
<<" 联系电话:" <personArray[ret].m_Phone <<'\t'
<<" 家庭住址:"<personArray[ret].m_Addr < }
system("pause"); //请按任意键继续
system("cls"); //清屏
}
//5.修改指定的联系人信息
void modifyPerson(struct 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;
//性别
int gender;
cout <<"请输入您的性别:(1表示男,0表示女)" < while (true)
{
cin >> gender;
if (gender == 1 || gender == 0)
{
abs->personArray[abs->m_Size].m_Gender = gender;
break;
}
else {
cout <<"您输入的性别有误,请重新输入!" < }
}
abs->personArray[ret].m_Gender = gender;
//年龄
int age;
cout <<"请输入年龄" < cin >> age;
abs->personArray[ret].m_Age = age;
//联系电话
string phone;
cout <<"请输入联系电话" < cin >> phone;
abs->personArray[ret].m_PhOne= phone;
//家庭住址
string address;
cout <<"请输入家庭住址" < cin >> address;
abs->personArray[ret].m_Addr = address;

cout <<"修改成功!" < }
else
{
cout <<"查无此人" < }
system("pause"); //请按任意键继续
system("cls"); //清屏
}
//6.清空联系人
void cleanPerson(struct Addressbooks* abs)
{
//将当前记录的联系人数置为0
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() {
int select; //创建用户选择输入的变量
//创建一个通讯录结构体
struct Addressbooks abs;
//初始化通讯录中当前人员个数
abs.m_Size = 0;
while (true)
{
//菜单界面的调用
showMenu();
cin >> select;
switch (select)
{
case 1://添加联系人
addPerson(&abs); //利用地址传递可以修改实参
break;
case 2://显示联系人
showPerson(&abs);
break;
case 3:
//删除联系人
{ //case中break;上面的代码过长要用{}括起来
cout <<"请输入删除的联系人的姓名:" < string name;
cin >> name;
if (isExist(&abs, name) == -1) {
cout <<"没有此人" < }else {
cout <<"找到此人" < }
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;
}
}
}


推荐阅读
  • 本文介绍了使用哈夫曼树实现文件压缩和解压的方法。首先对数据结构课程设计中的代码进行了分析,包括使用时间调用、常量定义和统计文件中各个字符时相关的结构体。然后讨论了哈夫曼树的实现原理和算法。最后介绍了文件压缩和解压的具体步骤,包括字符统计、构建哈夫曼树、生成编码表、编码和解码过程。通过实例演示了文件压缩和解压的效果。本文的内容对于理解哈夫曼树的实现原理和应用具有一定的参考价值。 ... [详细]
  • 本文介绍了C++中省略号类型和参数个数不确定函数参数的使用方法,并提供了一个范例。通过宏定义的方式,可以方便地处理不定参数的情况。文章中给出了具体的代码实现,并对代码进行了解释和说明。这对于需要处理不定参数的情况的程序员来说,是一个很有用的参考资料。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 本文介绍了一个程序,可以输出1000内能被3整除且个位数为6的所有整数。程序使用了循环和条件判断语句来筛选符合条件的整数,并将其输出。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 本文讨论了clone的fork与pthread_create创建线程的不同之处。进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合。在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性。但是二者之间的通讯需要通过专门的通讯机制,另外通过fork创建子进程系统开销很大。因此,在某些情况下,使用clone或pthread_create创建线程可能更加高效。 ... [详细]
  • 开发笔记:实验7的文件读写操作
    本文介绍了使用C++的ofstream和ifstream类进行文件读写操作的方法,包括创建文件、写入文件和读取文件的过程。同时还介绍了如何判断文件是否成功打开和关闭文件的方法。通过本文的学习,读者可以了解如何在C++中进行文件读写操作。 ... [详细]
  • Go语言实现堆排序的详细教程
    本文主要介绍了Go语言实现堆排序的详细教程,包括大根堆的定义和完全二叉树的概念。通过图解和算法描述,详细介绍了堆排序的实现过程。堆排序是一种效率很高的排序算法,时间复杂度为O(nlgn)。阅读本文大约需要15分钟。 ... [详细]
  • 深入理解Kafka服务端请求队列中请求的处理
    本文深入分析了Kafka服务端请求队列中请求的处理过程,详细介绍了请求的封装和放入请求队列的过程,以及处理请求的线程池的创建和容量设置。通过场景分析、图示说明和源码分析,帮助读者更好地理解Kafka服务端的工作原理。 ... [详细]
  • 李逍遥寻找仙药的迷阵之旅
    本文讲述了少年李逍遥为了救治婶婶的病情,前往仙灵岛寻找仙药的故事。他需要穿越一个由M×N个方格组成的迷阵,有些方格内有怪物,有些方格是安全的。李逍遥需要避开有怪物的方格,并经过最少的方格,找到仙药。在寻找的过程中,他还会遇到神秘人物。本文提供了一个迷阵样例及李逍遥找到仙药的路线。 ... [详细]
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • 如何在跨函数中使用内存?
    本文介绍了在跨函数中使用内存的方法,包括使用指针变量、动态分配内存和静态分配内存的区别。通过示例代码说明了如何正确地在不同函数中使用内存,并提醒程序员在使用动态分配内存时要手动释放内存,以防止内存泄漏。 ... [详细]
  • 本文介绍了一种轻巧方便的工具——集算器,通过使用集算器可以将文本日志变成结构化数据,然后可以使用SQL式查询。集算器利用集算语言的优点,将日志内容结构化为数据表结构,SPL支持直接对结构化的文件进行SQL查询,不再需要安装配置第三方数据库软件。本文还详细介绍了具体的实施过程。 ... [详细]
  • 本文介绍了Codeforces Round #321 (Div. 2)比赛中的问题Kefa and Dishes,通过状压和spfa算法解决了这个问题。给定一个有向图,求在不超过m步的情况下,能获得的最大权值和。点不能重复走。文章详细介绍了问题的题意、解题思路和代码实现。 ... [详细]
  • 深入解析Linux下的I/O多路转接epoll技术
    本文深入解析了Linux下的I/O多路转接epoll技术,介绍了select和poll函数的问题,以及epoll函数的设计和优点。同时讲解了epoll函数的使用方法,包括epoll_create和epoll_ctl两个系统调用。 ... [详细]
author-avatar
唯心任
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有