黑马C++ 通讯录管理系统

news/2025/12/5 22:14:24/文章来源:https://www.cnblogs.com/zhang-02/p/19313745
点击查看代码
#include <iostream>
#include <string> 
using namespace std;#define MAX 1000 // 最大人数 // 联系人结构体 
struct Person {string m_Name; // 姓名int m_Sex; // 性别:1男 2女int m_Age; string m_Phone;string m_Addr; 
};// 通讯录结构体
struct Addressbooks {struct Person personArray[MAX]; // 通讯录中保存的联系人数组int m_Size; // 通讯录中人员的个数
};// 菜单界面
void showMenu() {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;
}// 1、添加联系人信息
void addPerson(Addressbooks *abs) {// 判断电话本是否满了if (abs->m_Size == MAX) {cout << "通讯录已满,无法添加" << endl;return;} else {// 姓名string name;cout << "请输入姓名:" << endl;cin >> name;abs->personArray[abs->m_Size].m_Name = name;// 性别cout << "请输入性别:(1-男,2-女)" << endl;int sex = 0;while (true) {cin >> sex;if (sex == 1 || sex == 2) {abs->personArray[abs->m_Size].m_Sex = sex;break;}cout << "输入有误,请重新输入";}// 年龄 cout << "请输入年龄:" << endl;int age = 0;cin >> age;abs->personArray[abs->m_Size].m_Age = age;// 联系电话cout << "请输入联系电话:" << endl;string phone = "";cin >> phone;abs->personArray[abs->m_Size].m_Phone = phone;// 家庭住址cout << "请输入家庭住址:" << endl;string address;cin >> address;abs->personArray[abs->m_Size].m_Addr = address;// 更新通讯录人数abs->m_Size++;cout << "添加成功!" << endl;system("pause");system("cls");}
}// 2、显示所有联系人的信息
void showPerson(Addressbooks *abs) {if (abs->m_Size == 0) {cout << "当前记录为空" << endl;} else {for (int i = 0; i < abs->m_Size; i++) {cout << "姓名:" << abs->personArray[i].m_Name << "\t";cout << "性别:" << (abs->personArray[i].m_Sex == 1 ? "男" : "女") << "\t";cout << "年龄:" << abs->personArray[i].m_Age << "\t";cout << "电话:" << abs->personArray[i].m_Phone << "\t";cout << "住址:" << abs->personArray[i].m_Addr << endl;}}system("pause");system("cls");
}// 判断查询的人员姓名是否存在,存在返回在数组中的索引位置,不存在返回 -1
int isExist(Addressbooks *abs, string name) {for (int i = 0; i < abs->m_Size; i++) {if (abs->personArray[i].m_Name == name) {return i;}}return -1;
}// 3、删除指定的联系人信息
void deletePerson(Addressbooks *abs) {cout << "请输入要删除的联系人:" << endl;string name;cin >> name;int res = isExist(abs, name);if (res != -1) {for (int i = res; i < abs->m_Size; i++) {abs->personArray[i] = abs->personArray[i + 1];}abs->m_Size--;cout << "删除成功!" << endl;} else {cout << "查无此人!" << endl;}system("pause");system("cls");
}// 4、查找指定联系人信息
void findPerson(Addressbooks *abs) {cout << "请输入要查找的联系人:" << endl;string name;cin >> name;int res = isExist(abs, name);if (res != -1) {cout << "姓名:" << abs->personArray[res].m_Name << "\t";cout << "性别:" << abs->personArray[res].m_Sex << "\t";cout << "年龄:" << abs->personArray[res].m_Age << "\t";cout << "电话:" << abs->personArray[res].m_Phone << "\t";cout << "住址:" << abs->personArray[res].m_Addr << endl;} else {cout << "查无此人!" << endl;}system("pause");system("cls");
}// 5、修改指定联系人信息
void modifyPerson(Addressbooks *abs) {cout << "请输入要修改的联系人:" << endl;string name;cin >> name;int res = isExist(abs, name);if (res != -1) {// 姓名string new_Name;cout << "请输入姓名:" << endl;cin >> new_Name;abs->personArray[res].m_Name = new_Name;cout << "请输入性别:1-男,2-女:" << endl;// 性别int sex = 0;while (true) {cin >> sex;if (sex == 1 || sex == 2) {abs->personArray[res].m_Sex = sex;break;}cout << "输入有误,请重新输入~";}// 年龄cout << "请输入年龄:" << endl;int age = 0;cin >> age;abs->personArray[res].m_Age = age;// 联系电话cout << "请输入联系电话:" << endl;string phone = "";cin >> phone;abs->personArray[res].m_Phone = phone;// 家庭住址cout << "请输入家庭住址:" << endl;string address;cin >> address;abs->personArray[res].m_Addr = address;cout << "修改成功" << endl; } else {cout << "查无此人!" << endl;}system("pause");system("cls");
}// 6、清空所有联系人
void cleanPerson(Addressbooks *abs) {abs->m_Size = 0;cout << "通讯录已清空!" << endl;system("pause");system("cls");
} int main() {// 创建通讯录Addressbooks abs;// 初始化通讯录的人数abs.m_Size = 0;int select = 0;while (true) {showMenu();cin >> select;switch (select) {case 1:addPerson(&abs);break;case 2:showPerson(&abs);break;case 3:deletePerson(&abs);break;case 4:findPerson(&abs);break;case 5:modifyPerson(&abs);break;case 6:cleanPerson(&abs);break;case 0:cout << "欢迎下次使用" << endl;system("pause");return 0;break;default:break;}}system("pause");return 0;
}

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

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

相关文章

高级语言程序设计课程第八次个人作业

这个作业属于哪个课程:https://edu.cnblogs.com/campus/fzu/gjyycx 这个作业要求在哪里:https://edu.cnblogs.com/campus/fzu/gjyycx/homework/15590 学号:<102500401> 姓名:<林含悦> 11.13 1.2.3.6.7…

01背包

01背包模板

题解:P11811 [PA 2015] 人赢 / Mistrzostwa

废话 蒟蒻的第一篇题解! 正文 (内含一组 hack,如果你只 WA 第 18 个点)。 楼上的各位大佬,讲题思路已经很详细了。 因此这篇题解主要的目的是讲几个易错点。 那就看看我的“死亡回放”吧。 错误一 30pts。 死亡原…

详细介绍:GraphQL:让前端自己决定要什么数据

详细介绍:GraphQL:让前端自己决定要什么数据pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", &q…

2025.12.5

没课早起但是躺一天,洗澡,录入团课记录

实用指南:Configuration of TCP/IP with SSL and TLS for Database Connections

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

20232420 2025-2026-1 《网络与系统攻防技术》实验八实验报告

1.实验内容 1)编写一个含有表单的HTML 2)编写JavaScript并尝试注入攻击 3)正常安装、启动MySQL,建库、创建用户、修改密码、建表 4)编写PHP网页,连接数据库,进行用户认证 5)最简单的SQL注入,XSS攻击测试 6)安装DVW…

BZOJ1278 向量 vector

给定 \(n\) 个向量 \((x_i,y_i)\)。选出若干个向量,最大化向量和的模长,输出其平方。 \(1 \leq n \leq 10^5\)。考虑弱化条件。我们不妨找到一条直线 \(l\),最大化向量和在 \(l\) 上投影的长度。容易证明,一定能找…

14.jdbc第三步PreparedStatement防sql注入

1.首先要明白什么是sql注入、怎么做①sql注入理解: 通过将不可信输入伪装成 SQL 语法片段,篡改原始 SQL 的语法结构,迫使数据库执行非预期的非法操作。② 怎样做通过 URL 参数传参或者其他传参方式将含有sql语法的参…

详细介绍:【STL源码剖析】从源码看 heap:元素的 “下沉” 与 “上浮”

详细介绍:【STL源码剖析】从源码看 heap:元素的 “下沉” 与 “上浮”2025-12-05 21:34 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: au…

大信息环境搭建从零开始(十四)CentOS 7 系统更新源更换详解:阿里云镜像源配置完整指南

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

2025年度安全狗狗驱虫药品牌排行榜:专业评测助力科学养宠

摘要: 春冬季是宠物寄生虫高发期,选择安全有效的驱虫药成为养宠家庭首要关切。本文基于产品成分、临床数据、用户反馈及第三方权威检测,梳理出十大安全可靠的狗狗驱虫品牌,重点解析其核心优势与使用规范,为宠物主…

实用指南:Vue编程式路由导航

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

Ubuntu 22.04 与 24.04 常用操作命令

Ubuntu 22.04 与 24.04 常用操作命令 适用场景:系统管理员、开发人员针对 Ubuntu 22.04 LTS(Jammy Jellyfish)与 24.04 LTS(Noble Numbat)的日常运维 特别说明:Ubuntu 无 24.02 版本,推测为笔误,以下基于官方 …

【Java】String

目录前言内容概览更新记录String的创建1.直接创建2.String方法String常用API注意点String本身的特点1.String的对象是不可变字符串对象2.双引号创建的字符串对象存储在常量池中,且内容相同只能存储一份3.new String创…

拒绝智商税!2025最新学习机榜单发布,十大热门机型横向对比,一看就懂

随着教育智能硬件迈入“深水区”,2025年末的学习机市场已从单纯的硬件参数竞赛,转向教育资源厚度与AI技术有效性的综合较量。面对品牌宣传中各类“顶级”标签,消费者更需要一份基于真实产品力、剥离营销话术的理性参…

2025年12月留学生求职陪跑服务推荐榜:哪家更贴合专业背景定制

2025年,海归求职人数预计突破80万,叠加AI面试普及率超60%、企业缩编增效等新变量,留学生仅靠"海投+套模板"的生存空间被极度压缩。在此背景下,求职陪跑服务正从"可选项"变为"必选项"…

2025年留学生求职机构排名推荐指南 途鸽求职榜首领跑赛道

序言 对于留学生来说,求职从来不是“投简历→面试→拿offer”的简单流程——专业背景与岗位不匹配的迷茫、海投200份简历零面试的挫败、面试时不懂国内职场语境的紧张、拿到多份offer不知如何选择的纠结,甚至试用期怕…

网络安全的守护与利器:r/netsec 月度技术讨论与工具分享

本文聚焦于r/netsec子论坛的月度技术交流,不仅明确了技术讨论规范,更分享了honeyd工具的现代化更新版本,该工具用于在单一系统上模拟大量主机以迷惑网络扫描器。r/netsec 月度讨论与工具帖 欢迎在此提出与网络安全(…

2025留学生求职机构哪家强?5万offer全周期不限次服务+在职导师

对于2025届留学生而言,归国求职正面临前所未有的挑战:国内就业市场急剧变化带来的信息壁垒、跨专业求职的适配困境、以及职场本土化表达的能力短板。在这样的背景下,专业求职服务机构的价值愈发凸显。然而,市场鱼龙…