c++ 通讯录管理系统 黑马教程 (02)

个人笔记,这个是自己写的,未观看黑马教程,所以差异会比较大。

#include "iostream"
#include<conio.h>
using namespace std;
/*** 通讯录管理系统* 功能*      1.添加联系人*      2.显示联系人*      3.删除联系人*      4.查找联系人*      5.修改联系人*      6.清空联系人* @return*/
struct Phone {string name;int sex;string phone;string address;
};void add(Phone * listPhone,int);void show(Phone * listPhone,int);void deletePhone(Phone * listPhone,int);void searchPhone(Phone * listPhone,int);void editPhone(Phone * listPhone,int);void deleteAll(Phone * listPhone,int);int main() {struct Phone phoneList[100]={{"张工",1,"13519107598","咸阳秦都区"},{"马工",0,"13500000000","西安高新区"}};while (true) {system("cls");cout << "******************" << endl;cout << "***通讯录管理系统***" << endl;cout << "***1.添加联系人***" << endl;cout << "***2.显示联系人***" << endl;cout << "***3.删除联系人***" << endl;cout << "***4.查找联系人***" << endl;cout << "***5.修改联系人***" << endl;cout << "***6.清空联系人***" << endl;cout << "******************" << endl;cout << "请输入要执行的操作" << endl;int cinData;cin >> cinData;//获取数组元素个数int len = sizeof(phoneList) / sizeof(phoneList[0]);if (cinData == 1) {add(phoneList,len);}if (cinData == 2) {show(phoneList,len);}if (cinData == 3) {deletePhone(phoneList,len);}if (cinData == 4) {searchPhone(phoneList,len);}if (cinData == 5) {editPhone(phoneList,len);}if (cinData == 6) {deleteAll(phoneList,len);}}return 0;
}// 1.添加联系人
void add(Phone * pPhone,int len) {Phone newPhone;cout << "请输入要添加联系人的姓名" << endl;cin >> newPhone.name;cout << "请输入要添加联系人的性别" << endl;cout << "男=0" << endl;cout << "女=1" << endl;cin >> newPhone.sex;cout << "请输入要添加联系人的电话" << endl;cin >> newPhone.phone;cout << "请输入要添加联系人的地址" << endl;cin >> newPhone.address;for(int i=0;i<len;i++,pPhone++){if(pPhone->name.empty()){*pPhone=newPhone;cout<<"新用户添加成功"<<endl;break;}}cout << "按任意键继续" << endl;getchar();
}// 2.显示联系人
void show(Phone * pPhone,int len) {cout<<"数组大小为:"<<len<<endl;for(int i=0;i< len;i++,pPhone++){if(pPhone->name.empty()){cout<<"打印完成"<<endl;break;}cout<<"第"<<i+1<<"个联系人为: name="<<pPhone->name<<", sex="<<pPhone->sex<<", phone="<<pPhone->phone<<", address="<<pPhone->address<<";"<<endl;}cout << "按任意键继续" << endl;getch();
}// 3.删除联系人
void deletePhone(Phone *pPhone,int len) {string inName;Phone newPhone;cout<<"请输入要删除联系人的姓名:";cin>>inName;for(int i=0;i<len;i++,pPhone++){if(pPhone->name.empty()){cout<<"未查找到联系人"<<endl;break;}if(pPhone->name==inName){cout<<"第"<<i+1<<"个联系人为: name="<<pPhone->name<<", sex="<<pPhone->sex<<", phone="<<pPhone->phone<<", address="<<pPhone->address<<";"<<endl;*pPhone=newPhone;cout<<"第"<<i+1<<"个联系人为: name="<<pPhone->name<<", sex="<<pPhone->sex<<", phone="<<pPhone->phone<<", address="<<pPhone->address<<";"<<endl;cout<<"删除成功"<<endl;}}cout << "按任意键继续" << endl;getch();
}// 4.查找联系人
void searchPhone(Phone *pPhone,int len) {string inName;cout<<"请输入要查找联系人的姓名:";cin>>inName;for(int i=0;i<len;i++,pPhone++){if(pPhone->name.empty()){cout<<"未查找到联系人"<<endl;break;}if(pPhone->name==inName){cout<<"第"<<i+1<<"个联系人为: name="<<pPhone->name<<", sex="<<pPhone->sex<<", phone="<<pPhone->phone<<", address="<<pPhone->address<<";"<<endl;break;}}cout << "按任意键继续" << endl;getch();
}// 5.修改联系人
void editPhone(Phone *pPhone,int len) {cout<<"输入要修改联系人的名字"<<endl;string inName;cin>>inName;for(int i=0;i<len;i++,pPhone++){if(pPhone->name.empty()){cout<<"为找到联系人"<<endl;}if(pPhone->name==inName){Phone newPhone;cout << "请输入要添加联系人的姓名" << endl;cin >> newPhone.name;cout << "请输入要添加联系人的性别" << endl;cout << "男=0" << endl;cout << "女=1" << endl;cin >> newPhone.sex;cout << "请输入要添加联系人的电话" << endl;cin >> newPhone.phone;cout << "请输入要添加联系人的地址" << endl;cin >> newPhone.address;*pPhone=newPhone;break;}}cout << "按任意键继续" << endl;getch();
}// 6.清空联系人
void deleteAll(Phone *pPhone,int len) {cout<<"确认要清空联系人吗?"<<endl;cout<<"y=yes(确认清除);n=no(取消操作)"<<endl;char inChar;cin>>inChar;if(inChar=='n'){return;}if(inChar!='y'){cout<<"未确定是否删除,退出"<<endl;return;}if(inChar=='y'){struct Phone newPhoneList[100];for(int i=0;i<len;i++,pPhone++){Phone newPhone;*pPhone=newPhone;}cout<<"联系人列表清空成功!!!"<<endl;}cout << "按任意键继续" << endl;getch();
}

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

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

相关文章

Oracle的lag、lead函数使用

Oracle的lag、lead函数使用 一、LAG函数&#xff08;当前行之前&#xff09;二、LEAD函数&#xff08;当前行之后&#xff09; Oracle数据库中的LAG和LEAD函数可以用于查询行与前/后行之间的差异。 一、LAG函数&#xff08;当前行之前&#xff09; LAG函数返回分析窗口内的当前…

微信小程序社区户口管理的系统设计与实现

摘要 我国的户口管理制度由来已久&#xff0c;我国对于合法居民在新生儿的出生、户口的落地、迁移以及户口的注销上都有着详细的管理条例进行约束。通过户口的管理可以更好地对我国的居民人数进行有效的内容统计&#xff0c;在进行人口普查的过程中也能够实现更好的、更加精准的…

探索数据湖中的巨兽:Apache Hive分布式SQL计算平台浅度剖析!

文章目录 ◆ Apache Hive 概述1.1 分布式SQL计算1.2 Hive的优势 ◆ 模拟实现Hive功能2.1 元数据管理2.2 解析器2.3 基础架构2.4 Hive架构 ◆ Hive基础架构3.1 Hive架构图3.2 Hive组件3.2.1 元数据存储3.2.2 Driver驱动程序3.2.3 用户接口 ◆ Hive部署4.1 VMware虚拟机部署步骤一…

【学习笔记】求解线性方程组的G-S迭代法

求解线性方程组的G-S迭代法 // 运行不成功啊function [x,k,index] Gau_Seid(A,b,ep,it_max) % 求解线性方程组的G-S迭代法&#xff0c;其中 % A为方程组的系数矩阵 % b为方程组的右端项 % ep为精度要求&#xff0c;省缺为1e-5 % it_max为最大迭代次数&#xff0c;省缺为100 % …

新KG视点 | Jeff Pan、陈矫彦等——大语言模型与知识图谱的机遇与挑战

OpenKG 大模型专辑 导读 知识图谱和大型语言模型都是用来表示和处理知识的手段。大模型补足了理解语言的能力&#xff0c;知识图谱则丰富了表示知识的方式&#xff0c;两者的深度结合必将为人工智能提供更为全面、可靠、可控的知识处理方法。在这一背景下&#xff0c;OpenKG组织…

Docker运维篇

Docker运维篇 Docker 设置自启Docker 指定容器设置自启重启linux 计算机网络常见错误汇总centos 7 Docker容器启动报WARNING: IPv4 forwarding is disabled. Networking will not work Docker 设置自启 # 重启docker sudo systemctl enable docker# 设置开机自启 systemctl e…

eslint

什么是eslint ESLint 是一个根据方案识别并报告 ECMAScript/JavaScript 代码问题的工具&#xff0c;其目的是使代码风格更加一致并避免错误。 安装eslint npm init eslint/config执行后会有很多选项&#xff0c;按照自己的需求去选择就好&#xff0c;运行成功后会生成 .esli…

bpmnjs Properties-panel拓展(属性设置篇)

最近有思考工作流相关的事情&#xff0c;绘制bpmn图的工具认可度比较高的就是bpmn.js了&#xff0c;是一个基于node.js的流程图绘制框架。初始的框架只实现了基本的可视化&#xff0c;想在xml进行客制化操作的话需要拓展&#xff0c;简单记录下几个需求的实现过程。 修改基础 …

【数据分析】缺失值处理

1. 均值填充&#xff1a;对于数值型的特征&#xff0c;采用该特征在已有数据中的平均值或中位数来填充缺失值。 2. 众数填充&#xff1a;对于类别型的特征&#xff0c;采用该特征在已有数据中出现频率最高的类别来填充缺失值。 3. 插值法&#xff1a;通过已有的数据&#xff0c…

每天一道leetcode:542. 01 矩阵(图论中等广度优先遍历)

今日份题目&#xff1a; 给定一个由 0 和 1 组成的矩阵 mat &#xff0c;请输出一个大小相同的矩阵&#xff0c;其中每一个格子是 mat 中对应位置元素到最近的 0 的距离。 两个相邻元素间的距离为 1 。 示例1 输入&#xff1a;mat [[0,0,0],[0,1,0],[0,0,0]] 输出&#xff…

java八股文面试[多线程]——指令重排序

关于a的操作&#xff0c;由原来的6个指令&#xff0c;变成了4个指令。 1. 指令重排序的介绍 1&#xff09;指令重排序的类型 在执行程序时为了提高性能&#xff0c;编译器和处理器常常会对指令做重排序。 重排序分三种类型&#xff1a;编译器优化的重排序 编译器在不改变单线…

分布式一致性协议

在对一个分布式系统进行架构设计的过程中&#xff0c;往往会在系统的可用性和数据一致性之间进行反复的权衡&#xff0c;于是就产生了一系列的一致性协议。为了解决分布式一致性问题&#xff0c;在长期的探索研究过程中&#xff0c;涌现出了一大批经典的一致性协议和算法&#…

SpringMVC 第二天

第 1 章 ModelAttribute 和 SessionAttribute[ 应 用 ] 1.1ModelAttribute 1.1.1 使用说明 作用&#xff1a; 该注解是 SpringMVC4.3 版本以后新加入的。它可以用于修饰方法和参数。 出现在方法上&#xff0c;表示当前方法会在控制器的方法执行之前&#xff0c;先执行…

Open3D 进阶(7)Kmeans++点云聚类

目录 一、算法原理1、原理概述2、实现流程3、参考文献二、代码实现三、结果展示四、测试数据本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫。 一、算法原理 1、原理概述

【Android-Flutter】我的Flutter开发之旅

目录: 0、文档&#xff1a;1、在Windows上搭建Flutter开发环境&#xff08;1&#xff09;[使用中国镜像(❌详细看官方文档)](https://docs.flutter.dev/community/china)&#xff08;2&#xff09;[下载最新版Flutter SDK&#xff08;已包含Dart&#xff09;](https://docs.flu…

c 语言 算法 技巧 之 用移位来代替乘除

除法 当你需要计算一个数的一半时&#xff0c;通常我们会考虑使用除法运算&#xff08;/&#xff09;来实现。然而&#xff0c;计算机内部的运算中&#xff0c;除法通常比加法和乘法运算慢得多&#xff0c;因为除法需要更多的处理步骤。 位运算在这种情况下可以提供一个快速的…

[SQLITE_ERROR] SQL error or missing database (near “=“: syntax error)【已解决】

这个报的错误是语法错误&#xff0c;但是我并没有看出来这行代码有什么错。 通过排除掉下边两个问题解决的 从增加记录方法复制的下来的代码&#xff0c;只删除了关闭自动提交事务&#xff0c;但是connection.commit忘记删除executeQuery和executeUpdate方法的用法忘记了&…

什么是网络取证(Network Forensics)

企业采用新技术来检查其网络安全是否存在零日漏洞&#xff0c;与立即指示问题的物理层不同&#xff0c;黑客攻击尝试可能会被忽视并变得严重&#xff0c;直到对网络流量有一个整体的可见性。通过实时监控来跟踪其源和目标的流量&#xff0c;以查明问题或潜在问题的根源。 什么…

Redis之集群模式

一、Redis集群 一个节点就是一个运行在集群模式下的Redis服务器&#xff0c;Redis服务器在启动时会根据cluster-enabled配置选项是否为yes来决定是否开启服务器的集群模式。 Redis节点不会互相发现&#xff0c;连接各个节点的工作需要使用cluster meet命令来完成 CLUSTER MEE…

Java 语言实现归并排序算法

【引言】 归并排序算法是一种高效且稳定的排序算法。它采用分治法的思想&#xff0c;将数组反复分割成两个子数组&#xff0c;直到每个子数组只有一个元素。然后将这些子数组逐个合并&#xff0c;最终得到排序完毕的数组。本文将使用Java语言实现归并排序算法&#xff0c;并详细…