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

C++通讯录管理系统结构体,数组,函数

1、系统需求通讯录是一个可以记录亲人、好友信息的工具。本教程主要利用C来实现一个通讯录管理系统系统中需要实现的功能如下:●添加联系人:向通讯录中添加新人,信息包括(姓

1、系统需求
通讯录是一个可以记录亲人、好友信息的工具。
本教程主要利用C++来实现一个通讯录管理系统
系统中需要实现的功能如下:
●添加联系人:向通讯录中添加新人,信息包括(姓名、性别、年龄、联系电话、家庭住址)最多记录1000人
●显示联系人:显示通讯录中所有联系人信息
●删除联系人:按照姓名进行删除指定联系人
●查找联系人:按照姓名查看指定联系人信息
●修改联系人:按照姓名重新修改指定联系人
●清空联系人:清空通讯录中所有信息
●退出通讯录:退出当前使用的通讯录
步骤:
1.创建项目
2.封装函数显示该界面如void showMenu()
在main函数中调用封装好的函数
3.退出通讯录系统
思路:根据用户不同的选择,进入不同的功能,可以选择switch分支结构, 将整个架构进行搭建
当用户选择0时候,执行退出,选择其他先不做操作,也不会退出程序
4.实现添加联系人功能,联系人上限为1000人,联系人信息包括(姓名、性别、年龄、联系电话、家庭住址)
添加联系人实现步骤:
●设计联系人结构体
●设计通讯录结构体
。maln函数中创建通讯录
,封装添加联系人函数
●测试添加联系人功能
5.显示通讯录中已有的联系人信息
显示联系人实现步骤:
●封装显示联系人函数
●测试显示联系人功能
6.按照姓名进行删除指定联系人
删除联系人实现步骤:
●封装检测联系人是否存在
●封装删除联系人函数: 如果要删除的联系人存在,那么就删除该联系人
●测试删除联系人功能
7.按照姓名查看指定联系人信息
查找联系人实现步骤
●封装查找联系人函数
先看是否存在,若存在,就显示信息
●测试查找指定联系人
8.修改联系人
先确定联系人是否存在
若存在就修改相关属性信息(类似于添加)
9.清空通讯录中所有信息
清空联系人实现步骤
●封装清空联系人函数
●测试清空联系人
在这里插入图片描述

#include
#include
#define MAX 1000
using namespace std;
//联系人结构体
struct lianxiren {string name;string adress;int sex;int age;string phonenumber;};
struct tongxunlu {struct lianxiren a[MAX];//通讯录中联系人数组int size;//通讯录中人员个数
};
void showMenu() {//因为其他函数要调用该函数&#xff0c;所以要把这个函数的定义放在最前面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;cout << "请选择&#xff1a;" << endl;
}
void addper(tongxunlu * A ) {//判断通讯领域是否已满&#xff0c;如果满了就不再添加if (A->size &#61;&#61; MAX){cout << "通讯录已满&#xff0c;无法添加&#xff01;" << endl;return;}else {string name;cout << "请输入姓名&#xff1a;" << endl;cin>>name;A->a[A->size].name &#61; name;cout << "请选择姓别&#xff1a;1.男 2.女" << endl;int sex &#61; 0;while (true) {//要是输入的有误&#xff0c;就重新输入cin >> sex;if (sex &#61;&#61; 1 || sex &#61;&#61; 2) {A->a[A->size].sex &#61; sex;break;}else cout << "输入有误&#xff0c;请重新输入。" << endl;}cout << "请输入年龄&#xff1a;" << endl;int age &#61; 0;cin >> age;if(age>0&&age<120){A->a[A->size].age &#61; age;}cout << "请输入电话号码&#xff1a;" << endl;string phonenumber;cin >> phonenumber;A->a[A->size].phonenumber &#61; phonenumber;cout << "请输入地址&#xff1a;" << endl;string adress;cin >> adress;A->a[A->size].adress &#61; adress;//更新通讯录人数A->size&#43;&#43;;cout << "添加成功" << endl;system("pause");system("cls");//清屏操作}}
void show(tongxunlu *A) {if (A->size &#61;&#61; 0) {cout << "数组中元素为0" << endl;}else {for (int i &#61; 0; i < A->size; i&#43;&#43;) {cout << "姓名&#xff1a;" << A->a[i].name <<"\t";cout << "性别&#xff1a;" << (A->a[i].sex&#61;&#61;1?"男":"女")<< "\t";//括号很重要cout << "年龄&#xff1a;" << A->a[i].age << "\t";cout << "电话号码&#xff1a;" << A->a[i].phonenumber << "\t";cout << "住址&#xff1a;" << A->a[i].adress << endl;}}
}
//检测该联系人是否存在
int isExit(tongxunlu *A, string name) {for (int i &#61; 0; i < A->size; i &#43;&#43; ) {if (A->a[i].name &#61;&#61; name) {return i&#43;1;}else return 0;}}
//删除联系人
void deleteper(tongxunlu *A) {cout << "请输入要删除联系人的姓名:" << endl;string name;cin >> name;//如果这个人存在&#xff0c;就要输出的时候不显示他&#xff0c;交换数组下标&#xff0c;把要删除的移到最后一个&#xff0c;人数-1if (isExit(A,name)) { int flag &#61; isExit(A, name) - 1;for (int i &#61; flag; i < A->size; i&#43;&#43;) {A->a[i] &#61; A->a[i &#43; 1];}A->size--;cout << "删除成功&#xff01;" << endl;}else cout << "这个人不存在&#xff01;" << endl;}
//查找指定联系人
void findper(tongxunlu *A) {cout << "请输入您要查找的联系人&#xff1a;" << endl;string name;cin >> name;int flag &#61; isExit(A, name)-1;if (isExit(A, name)) {cout << "姓名&#xff1a;" << A->a[flag].name << "\t" << "性别&#xff1a;" << A->a[flag].sex << "\t" << "年龄&#xff1a;" << A->a[flag].age << "\t" << "电话&#xff1a;" << A->a[flag].phonenumber << "\t" << "住址:" << A->a[flag].adress << endl;}else cout << "这个人不存在&#xff01;" << endl;}
void update(tongxunlu *A) {cout << "请输入要修改的联系人姓名&#xff1a;" << endl;string name;cin >> name;int flag &#61; isExit(A, name)-1;if (isExit(A, name)) {cout << "请输入姓名&#xff1a;" << endl;cin >> name;A->a[flag].name &#61; name;cout << "请选择姓别&#xff1a;1.男 2.女" << endl;int sex &#61; 0;while (true) {//要是输入的有误&#xff0c;就重新输入cin >> sex;if (sex &#61;&#61; 1 || sex &#61;&#61; 2) {A->a[flag].sex &#61; sex;break;}else cout << "输入有误&#xff0c;请重新输入。" << endl;}cout << "请输入年龄&#xff1a;" << endl;int age &#61; 0;cin >> age;if (age > 0 && age < 120) {A->a[flag].age &#61; age;}cout << "请输入电话号码&#xff1a;" << endl;string phonenumber;cin >> phonenumber;A->a[flag].phonenumber &#61; phonenumber;cout << "请输入地址&#xff1a;" << endl;string adress;cin >> adress;A->a[flag].adress &#61; adress;//更新通讯录人数cout << "修改成功" << endl;system("pause");system("cls");//按任意键清屏操作}else cout << "这个人不存在&#xff01;" << endl;}
//只需要隐藏通讯录数组的人&#xff0c;将人数置为0
int qingkong(tongxunlu*A) {cout << "确定要清空所有联系人吗&#xff1f;1 是 0否 " << endl;int a;cin >> a;if (a) {A->size &#61; 0;cout << "通讯录已经清空&#xff01;" << endl;system("pause");system("cls");}else return 0;}int main() {tongxunlu A;A.size &#61; 0;int a;while (true) {showMenu();cin >> a;switch (a) {case 0:cout << "谢谢使用" << endl; return 0; break;//case语句像这种小段代码可以不用复合语句&#xff0c;但要是比较大段的&#xff0c;应该用{}case 1: {addper(&A); break; }case 2:show(&A); break;case 3:deleteper(&A); break;case 4:findper(&A); break;case 5:update(&A); break;case 6:qingkong(&A); break;default:cout << "请输入正确的选项数字&#xff01;"<<endl; break;}}system("pause");return 0;}

功能测试完毕&#xff0c;页面显示是否清屏可以根据自己的需要来进行选择


推荐阅读
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 本文介绍了解决二叉树层序创建问题的方法。通过使用队列结构体和二叉树结构体,实现了入队和出队操作,并提供了判断队列是否为空的函数。详细介绍了解决该问题的步骤和流程。 ... [详细]
  • 开发笔记:实验7的文件读写操作
    本文介绍了使用C++的ofstream和ifstream类进行文件读写操作的方法,包括创建文件、写入文件和读取文件的过程。同时还介绍了如何判断文件是否成功打开和关闭文件的方法。通过本文的学习,读者可以了解如何在C++中进行文件读写操作。 ... [详细]
  • 李逍遥寻找仙药的迷阵之旅
    本文讲述了少年李逍遥为了救治婶婶的病情,前往仙灵岛寻找仙药的故事。他需要穿越一个由M×N个方格组成的迷阵,有些方格内有怪物,有些方格是安全的。李逍遥需要避开有怪物的方格,并经过最少的方格,找到仙药。在寻找的过程中,他还会遇到神秘人物。本文提供了一个迷阵样例及李逍遥找到仙药的路线。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文介绍了一种划分和计数油田地块的方法。根据给定的条件,通过遍历和DFS算法,将符合条件的地块标记为不符合条件的地块,并进行计数。同时,还介绍了如何判断点是否在给定范围内的方法。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • IOS开发之短信发送与拨打电话的方法详解
    本文详细介绍了在IOS开发中实现短信发送和拨打电话的两种方式,一种是使用系统底层发送,虽然无法自定义短信内容和返回原应用,但是简单方便;另一种是使用第三方框架发送,需要导入MessageUI头文件,并遵守MFMessageComposeViewControllerDelegate协议,可以实现自定义短信内容和返回原应用的功能。 ... [详细]
  • 本文介绍了使用哈夫曼树实现文件压缩和解压的方法。首先对数据结构课程设计中的代码进行了分析,包括使用时间调用、常量定义和统计文件中各个字符时相关的结构体。然后讨论了哈夫曼树的实现原理和算法。最后介绍了文件压缩和解压的具体步骤,包括字符统计、构建哈夫曼树、生成编码表、编码和解码过程。通过实例演示了文件压缩和解压的效果。本文的内容对于理解哈夫曼树的实现原理和应用具有一定的参考价值。 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • c语言\n不换行,c语言printf不换行
    本文目录一览:1、C语言不换行输入2、c语言的 ... [详细]
author-avatar
只被你耐_396
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有