分步解析C++实现通讯录管理系统

点击蓝字

cc5b04d909d4a326c2758e3d4686dd28.png

关注我们

来源于网络,侵删

一、前言

建议亲手写一遍代码,感受指针神奇的魅力;
可以帮助你更好的巩固知识体系,熟悉指针,结构体与函数一起使用时的妙处

完成通讯录管理系统所需知识体系

  • 结构体

  • 指针

  • 函数的封装

  • 指针与函数的结合使用

  • 指针与结构体的结合使用

二、结构体

1、联系人结构体

struct person
{string name;//姓名string sex; //性别int age;  //年龄string phone;//手机号string home;//地址};

2、通讯录结构体

struct addressbook
{struct person personArray[MAX]; //通讯录扩展到100;int size=0;  //当前联系人个数(后面就相当于i++)
};


三、函数模块

  • void menu();//菜单

  • void putit(addressbook* add);//添加联系人

  • void showperson(addressbook* add);// 显示联系人

  • int if_include(addressbook* add, string name);//判断联系人

  • void deleteperson(addressbook* add, int i);//删除联系人

  • void findPerson( addressbook* add);//查找联系人

  • void cleanperson(struct addressbook* add);//清空所有联系人

1、菜单

void menu()
{cout << endl;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;
}

2、添加联系人

void putit(addressbook* add)//添加联系人功能
{if (add->size == MAX)cout << "通讯录已满" << endl;else{string name;string sex;int age;string phone;string home;cout << "请输入姓名" << endl;cin >> name;add->personArray[add->size].name = name;cout << "请输入姓别" << endl;cin >> sex;add->personArray[add->size].sex = sex;cout << "请输入年龄" << endl;cin >> age;add->personArray[add->size].age = age;cout << "请输入电话号码" << endl;cin >> phone;add->personArray[add->size].phone = phone;cout << "请输入家庭住址" << endl;cin >> home;add->personArray[add->size].home = home;add->size++;cout << "添加联系人成功" << endl;}system("pause");system("cls");menu();
}

添加联系人函数中为什么要使用指针?
因为值传递中形参无法改变实参;
而利用指针的地址传递可以通过函数中的形参改变实参;

3、显示联系人

void showperson(addressbook* add)
{for (int i = 0; i <add->size; i++){cout << "姓名:" << add->personArray[i].name;cout << "\t姓别:" << add->personArray[i].sex;cout << "\t年龄:" << add->personArray[i].age;cout << "\t电话号码:" << add->personArray[i].phone;cout << "\t家庭住址:" << add->personArray[i].home << endl;}system("pause");system("cls");menu();
}

4、判断联系人

int if_include(addressbook* add, string name)
{for (int i = 0; i < add->size; i++){if (name == add->personArray[i].name){return i;}else{return -1;}}}

5、删除联系人

void deleteperson(addressbook* add, int i)
{for (; i < add->size; i++){add->personArray[i] = add->personArray[i + 1];}system("pause");system("cls");
}

6、查找联系人

void findPerson( addressbook* add)
{cout << "请输入您想要查找的联系人:" << endl;string name;cin >> name;int ret = if_include(add, name);if (ret == -1){cout << "查无此人" << endl;}else{   //查到此人,进行显示操作int i = ret;cout << "姓名:" << add->personArray[i].name << "\t";cout << "性别:" << add->personArray[i].sex << "\t";cout << "年龄:" << add->personArray[i].age << "\t";cout << "联系方式:" << add->personArray[i].phone << "\t";cout << "地址:" << add->personArray[i].home << endl;}//按任意键清屏system("pause");system("cls");
}

7、清空所有联系人

void cleanperson(struct addressbook* add)//清空所有联系人
{cout << "是否确认清空?" << endl;cout << "1 --- 是" << endl;cout << "2 --- 否" << endl;int a;cin >> a;if (a == 1){add->size = 0;//将当前记录联系人数量置为0,做逻辑上的清空操作cout << "通讯录已清空" << endl;}system("pause");system("cls");
}

四、main函数

int main()
{menu();addressbook add;//定义一个通讯录int choice=1;while (choice != 0){cin >> choice;switch (choice)//选择{case 1: putit(&add);break;case 2: showperson(&add);break;case 3: {cout << "请输入你要删除的人的名字" << endl;string aname;cin >> aname;if (if_include(&add, aname) == -1){cout << "查无此人" << endl;break;}if (if_include(&add, aname)){deleteperson(&add, if_include(&add, aname));}}break; case 4:break;case 5:break;case 6:break;case 0: cout << "欢迎下次使用" << endl;return 0;break;default: {cout << "输入不合法,请重新输入" << endl;break; }}}
}

五、源代码

#include<iostream>
using namespace std;
#include<string>
#define MAX 100struct person
{string name;//姓名string sex; //性别int age;  //年龄string phone;//手机号string home;//地址};
struct addressbook
{struct person personArray[MAX]; //通讯录扩展到100;int size=0;  //当前联系人个数(后面就相当于i++)
};
void menu();//菜单
void putit(addressbook* add);
void showperson(addressbook* add); 
int if_include(addressbook* add, string name);
void deleteperson(addressbook* add, int i);
void findPerson(struct addressbooks* add);//查找联系人
void cleanperson(struct addressbook* add);//清空所有联系人
int main()
{menu();addressbook add;int choice=1;while (choice != 0){cin >> choice;switch (choice){case 1: putit(&add);break;case 2: showperson(&add);break;case 3: {cout << "请输入你要删除的人的名字" << endl;string aname;cin >> aname;if (if_include(&add, aname) == -1){cout << "查无此人" << endl;break;}if (if_include(&add, aname)){deleteperson(&add, if_include(&add, aname));}}break; case 4:break;case 5:break;case 6:break;case 0: cout << "欢迎下次使用" << endl;return 0;break;default: {cout << "输入不合法,请重新输入" << endl;break; }}}
}
void menu()
{cout << endl;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;
}
void putit(addressbook* add)//添加联系人功能
{if (add->size == MAX)cout << "通讯录已满" << endl;else{string name;string sex;int age;string phone;string home;cout << "请输入姓名" << endl;cin >> name;add->personArray[add->size].name = name;cout << "请输入姓别" << endl;cin >> sex;add->personArray[add->size].sex = sex;cout << "请输入年龄" << endl;cin >> age;add->personArray[add->size].age = age;cout << "请输入电话号码" << endl;cin >> phone;add->personArray[add->size].phone = phone;cout << "请输入家庭住址" << endl;cin >> home;add->personArray[add->size].home = home;add->size++;cout << "添加联系人成功" << endl;}system("pause");system("cls");menu();
}
void showperson(addressbook* add)
{for (int i = 0; i <add->size; i++){cout << "姓名:  " << add->personArray[i].name;cout << "\t姓别:  " << add->personArray[i].sex;cout << "\t年龄:  " << add->personArray[i].age;cout << "\t电话号码:  " << add->personArray[i].phone;cout << "\t家庭住址:  " << add->personArray[i].home << endl;}system("pause");system("cls");menu();
}
int if_include(addressbook* add, string name)
{for (int i = 0; i < add->size; i++){if (name == add->personArray[i].name){return i;}else{return -1;}}}
void deleteperson(addressbook* add, int i)
{for (; i < add->size; i++){add->personArray[i] = add->personArray[i + 1];}system("pause");system("cls");
}void findPerson( addressbook* add)
{cout << "请输入您想要查找的联系人:" << endl;string name;cin >> name;int ret = if_include(add, name);if (ret == -1){cout << "查无此人" << endl;}else{   //查到此人,进行显示操作int i = ret;cout << "姓名:" << add->personArray[i].name << "\t";cout << "性别:" << add->personArray[i].sex << "\t";cout << "年龄:" << add->personArray[i].age << "\t";cout << "联系方式:" << add->personArray[i].phone << "\t";cout << "地址:" << add->personArray[i].home << endl;}//按任意键清屏system("pause");system("cls");
}
void cleanperson(struct addressbook* add)//清空所有联系人
{cout << "是否确认清空?" << endl;cout << "1 --- 是" << endl;cout << "2 --- 否" << endl;int a;cin >> a;if (a == 1){add->size = 0;//将当前记录联系人数量置为0,做逻辑上的清空操作cout << "通讯录已清空" << endl;}system("pause");system("cls");
}

建议大家可以试着分文件编写代码,也方便查看

六、运行结果

44f4d581694941f383bcc0f4b82f7c1d.png

dff17760d3b4822303c801d8a5e105e8.png

8323c20fad7b83f9f01f03cefb167697.gif

如果你年满18周岁以上,又觉得学【C语言】太难?想尝试其他编程语言,那么我推荐你学Python,现有价值499元Python零基础课程限时免费领取,限10个名额!
▲扫描二维码-免费领取

e4dd33f9acc7c6743f7b486027d5888b.gif

戳“阅读原文”我们一起进步

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/337282.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何用C++实现动态放烟花(附源码)

点击蓝字关注我们来源于网络&#xff0c;侵删一、前言C实现的放烟花程序用到了EGE图形库&#xff0c;没有的需要自行安装可调项&#xff1a;背景图和背景音乐、粒子模糊度、亮度以及上升速度的参数。实现的动态烟花非常好看&#xff0c;可以做给女朋友或者表白用&#xff0c;呵…

nginx哪个版本性能好_nginx性能为什么好

nginx在启动后&#xff0c;在unix系统中会以daemon的方式在后台运行&#xff0c;后台进程包含一个master进程和多个worker进程。我们也可以手动地关掉后台模式&#xff0c;让nginx在前台运行&#xff0c;并且通过配置让nginx取消master进程&#xff0c;从而可以使nginx以单进程…

metrics_FlexyPool如何支持Dropwizard Metrics包重命名

metrics介绍 FlexyPool严重依赖Dropwizard &#xff08;以前称为Codahale&#xff09;度量标准来监视连接池的使用情况 。 集成到Dropwizard中后&#xff0c;程序包名称必然会被重命名 。 因此&#xff0c;4.0.0版本将使用io.dropwizard.metrics软件包名称代替com.codahale.me…

用C++写一个http服务器/web服务器

点击蓝字关注我们来源于网络&#xff0c;侵删本篇文章不会涉及到很多复杂的概念&#xff0c;也没有写很难读懂的模板函数&#xff0c;代码简单可读&#xff0c;本篇文章送给每一个想自己用C写一个http服务器的小伙伴&#xff01;高手们、大佬们当然可以不用看的啦&#xff01;正…

repl java9_Java 9抢先体验:与JShell进行动手实践– Java REPL

repl java9从今天开始&#xff0c;如何开始使用Java 9的最酷功能之一&#xff1f; 上周末&#xff0c;我终于开始尝试使用Java 9的早期访问版本。第一站是JShell&#xff0c;它也被称为Project Kulla。 首先让我鼓起勇气尝试早期访问Java版本的原因。 那就对了。 Java 9的正式…

java iterator获取索引_2020年Java面试题最新整理(1625)

16.Java集合框架是什么&#xff1f;说出一些集合框架的优点&#xff1f;每种编程语言中都有集合&#xff0c;最初的Java版本包含几种集合类&#xff1a;Vector、Stack、HashTable和Array。随着集合的广泛使用&#xff0c;Java1.2提出了囊括所有集合接口、实现和算法的集合框架。…

搞定红黑树(C++实现)

点击蓝字关注我们来源于网络&#xff0c;侵删红黑树的概念红黑树&#xff0c;是一种二叉搜索树&#xff0c;但在每个结点上增加一个存储位表示结点的颜色&#xff0c;可以是红色或黑色。通过对任何一条从根到叶子的路径上各个结点着色方式的限制&#xff0c;红黑树确保没有一条…

java launcher_JAR清单类路径不仅适用于Java Application Launcher

java launcher自从我开始学习Java以来​​&#xff0c;我几乎已经知道&#xff0c; 清单文件中的Class-Path标头字段为可执行JAR &#xff08;具有由另一个称为Main-Class清单指定应用程序起点的 JAR&#xff09;指定了相对运行时类路径。 一个同事最近碰到一个让我感到惊讶&am…

C语言实现银行ATM存取款系统 | 附源码

点击蓝字关注我们来源于网络&#xff0c;侵删银行ATM存取款系统银行ATM存取款系统业务描述如下&#xff1a;银行ATM存取款系统能为用户提供存款、取款、查询、转账和修改密码的功能。为了模拟真实的ATM业务环境&#xff0c;本系统必须实现存款、取款、查询、转账、修改密码以及…

php 链接文件名_7、php-fpm进程管理

1、进程管理php-fpm采用的是master-worker的进程方式。其中&#xff0c;master负责fork worker进程;其次&#xff0c;注册信号&#xff0c;通过信号进行管理worker负责监听端口&#xff0c;等待链接&#xff0c;处理具体的逻辑如下图所示2、信号管理master进程可以理解如下信号…

C语言代码实现平衡二叉树|图解+详细代码

点击蓝字关注我们来源于网络&#xff0c;侵删1. 什么是平衡二叉树平衡二叉树&#xff0c;我们也称【二叉平衡搜索树/AVL】,树中任何节点的两个子树的高度最大差别为1&#xff0c;巴拉巴拉。。。(https://baike.baidu.com/item/AVL树/10986648?fraladdin)但是有个注意的点: 平衡…

cba比赛比分预测_【CBA直播】深圳vs广东前瞻:深圳战广东再掀反攻?

北京时间4月13日晚19点35分&#xff0c;CBA季后赛半决赛第三回合&#xff0c;深圳队主场迎战广东队。尽管目前双方总比分深圳以0-2落后对手&#xff0c;但他们在第二战的顽强表现给人留下了深刻印象。回归主场作战的他们&#xff0c;将在沈梓捷和贺希宁的带领下&#xff0c;力争…

C语言内存泄漏问题及其检视方法

点击蓝字关注我们来源于网络&#xff0c;侵删通过介绍内存泄漏问题原理及检视方法&#xff0c;希望后续能够从编码检视环节就杜绝内存泄漏导致的网上问题发生。本文通过介绍内存泄漏问题原理及检视方法&#xff0c;希望后续能够从编码检视环节就杜绝此类问题发生。预防内存泄漏…

未定义与 struct 类型的输入参数相对应的函数 fetch_引入鲁棒性作为连续参数,这种新损失函数实现了自适应、随时变换...

编辑&#xff1a;陈萍损失函数是机器学习里最基础也是最为关键的一个要素&#xff0c;其用来评价模型的预测值和真实值不一样的程度。最为常见的损失函数包括平方损失、指数损失、log 对数损失等损失函数。这里回顾了一种新的损失函数&#xff0c;通过引入鲁棒性作为连续参数&a…

清理jdk注册表_JDK 9早期版本安装后的Windows注册表清理

清理jdk注册表在我的上一篇博文中 &#xff0c;我演示了在安装早期版本的JDK 9&#xff08;内部版本68&#xff09;之后围绕Oracle Java符号链接 &#xff08;基于Windows的计算机上的C:\ProgramData\Oracle\Java\javapath\目录&#xff09;的问题的解决方案。这似乎阻止了早期…

汇编语言调用C语言/C++实例:乘法表

点击蓝字关注我们来源于网络&#xff0c;侵删现在编写一个简单的应用程序&#xff0c;提示用户输入整数&#xff0c;通过移位的方式将其与 2 的幕 (2〜2ⁿ) 相乘&#xff0c;并用填充前导空格的形式再次显示每个乘积。输入-输出使用 C。汇编模块将调用 3 个 C 编写的函数。程序…

rect函数_R函数不会写,quot;抄quot;总会吧!

前面我们简单的介绍了R函数。有些人可能会说&#xff0c;我现在的R水平有限&#xff0c;还不足以写出很高级的函数&#xff0c;该怎么办&#xff1f;俗话说前人栽树后人乘凉&#xff0c;他山之石可以攻玉&#xff0c;鲁迅同志也提出过“拿来”主义。已经有前人&#xff0c;高手…

10个超赞的C语言开源项目,强烈推荐!

点击蓝字关注我们来源于网络&#xff0c;侵删今天分享10个超赞的C语言开源项目&#xff0c;希望这些内容能对大家有所帮助&#xff01;目录&#xff1a;1. Webbench2. Tinyhttpd3. cJSON4. CMockery5. Libev6. Memcached7. Lua8. SQLite9. UNIX v610. NETBSD1. WebbenchWebbenc…

jboss性能指标_JBoss BRMS复杂事件处理(CEP)性能基准

jboss性能指标技术来了又去&#xff0c;但是一件事保持不变。 在设计企业解决方案时&#xff0c;我们喜欢使我们的生活更轻松的复杂组件&#xff0c;作为建筑师和开发人员&#xff0c;我们一直在寻找使我们的生活更轻松的方法。 一种方法是跟上与感兴趣的技术有关的流行新站点…

C语言经验分享:二维指针与二维数组的两种错误用法

点击蓝字关注我们来源于网络&#xff0c;侵删引子首先看一段代码:void test(int *p) {}int main() {int arr[] {30, 450,14,5};test(arr);return 0; }毫无疑问&#xff0c;上面这段代码是运行OK的。因为C语言标准中有以下规则:在函数参数的声明中&#xff0c;数组名被编译器当作…