分步解析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,一经查实,立即删除!

相关文章

python代码可以内嵌在asp文件中_在IE中使用Python作为开发脚本(转)

正在学习python&#xff0c;除了语法优美&#xff0c;功能强大外&#xff0c;最看重的是它的可扩展性&#xff0c;可以嵌入到asp和其他一些开发语言中。对IIS配置了.py的扩展名解析&#xff0c;可以对.py的页面进行访问&#xff0c;但asp页面的python脚本仍然无法解析&#xff…

服务器禁止head 请求_编写下载服务器。 第四部分:有效地执行HEAD操作

服务器禁止head 请求HEAD是一个经常被遗忘的HTTP方法&#xff08;动词&#xff09;&#xff0c;其行为类似于GET&#xff0c;但不返回正文。 您使用HEAD来检查资源的存在&#xff08;如果不存在&#xff0c;它应该返回404&#xff09;&#xff0c;并确保您的缓存中没有陈旧的版…

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

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

java8 streams_Java SE 8新功能介绍:使用Streams API处理集合

java8 streams使用Java SE 8 Streams的代码更干净&#xff0c;易读且功能强大..... 在“ Java SE 8新功能导览”系列的这篇文章中&#xff0c;我们将深入解释并探索代码&#xff0c;以了解如何使用流遍历集合&#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…

python的智能算法_scikit-opt——Python中的群体智能优化算法库

安装pip install scikit-opt对于当前的开发者版本&#xff1a;git clone gitgithub.com:guofei9987/scikit-opt.gitcd scikit-optpipinstall .Genetic Algorithm第一步&#xff1a;定义你的问题importnumpy as npdefschaffer(p):This function has plenty of local minimum, wi…

用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方法重载和重载方法_Java 8的方法参考进一步限制了重载

java方法重载和重载方法方法重载一直是一个充满喜忧参半的话题。 我们已经在博客上介绍了它&#xff0c;并介绍了几次警告&#xff1a; 您会后悔对Lambdas应用重载&#xff01; 保持干燥&#xff1a;方法重载 为什么每个人都讨厌操作员超载 API设计师&#xff0c;请小心 重…

在python中字符串可以使用什么来表示_Python 字符串定义

例如&#xff1a;’string’、”string”、”””string”””或者是”’string”’。在使用上&#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;力争…

spring 启动进度_在Web浏览器中显示Spring应用程序启动的进度

spring 启动进度重新启动企业应用程序时&#xff0c;客户打开Web浏览器时会看到什么&#xff1f; 他们什么也没看到&#xff0c;服务器还没有响应&#xff0c;因此Web浏览器显示ERR_CONNECTION_REFUSED 应用程序前面的Web代理&#xff08;如果有&#xff09;注意到它已关闭&a…

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

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