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

C++结构体案例通讯录系统

运用学到的C结构体知识创建一个通讯录系统,有7大功能:添加联系人:向通讯录中添加联系人姓名、电话、性别、年龄、家庭住址,最

运用学到的C++结构体知识创建一个通讯录系统,有7大功能:

  • 添加联系人:向通讯录中添加联系人姓名、电话、性别、年龄、家庭住址,最多可添加1000人。
  • 显示联系人:显示通讯录中所有联系人信息
  • 删除联系人:按照姓名进行删除指定联系人
  • 查找联系人:按照姓名查找指定联系人
  • 修改联系人:按照姓名重新修改指定联系人
  • 清空联系人:清空通讯录中所有信息
  • 退出通讯录:退出当前使用的通讯录

1、显示菜单栏

功能:显示用户可以执行的操作,实现菜单功能。

void showMenu()
{cout <<"*******************************" <}

效果&#xff1a;

2、退出通讯录

功能&#xff1a;退出通讯录系统

思路&#xff1a;根据用户的选择&#xff0c;执行不同的操作&#xff0c;可以用switch分支结构。

int main()
{int select &#61; 0;//输入你的选择项while(true){showMenu();cin >> select;switch (select){case 0://退出通讯录cout <<"欢迎下次使用" <}

效果&#xff1a;

3、添加联系人

功能&#xff1a;向通讯录中添加新的联系人及其其他相关信息。

  1. 创建联系人结构体
  2. 创建通讯录
  3. 添加联系人函数
  4. 测试功能

3.1 创建联系人结构体

struct contact
{string name;//姓名string gender;//性别int age;//年纪string phone_number;//联系电话string address;//地址
};

3.2 创建通讯录

# define MAX 1000

struct contact_book {struct contact array[MAX];//通讯录的最大容量int m_size;//通讯录目前有多少联系人
};

3.3 添加联系人函数

功能&#xff1a;添加新的联系人

需要判断一下通讯录容量是否达到上限。

void addPreson(struct contact_book *a)
{string name, gender, phone_number, address;int age;if (a->m_size &#61;&#61; MAX) {cout <<"通讯录已满&#xff0c;无法添加" <m_size;string name, addre, phone_number, gender;int age;cout <<"姓名&#xff1a;";cin >> name;a->array[index].name&#61;name;cout <<"性别&#xff1a;";cin >> gender;while (gender !&#61; "男" && gender !&#61; "女"){cout <<"性别输入有误&#xff0c;请重新输入"<> gender;}a->array[index].gender &#61; gender;cout <<"年龄&#xff1a;";cin >> age;a->array[index].age&#61;age;cout <<"联系电话&#xff1a;";cin >> phone_number;a->array[index].phone_number&#61;phone_number;cout <<"住址&#xff1a;";cin >> addre;a->array[index].address&#61;addre;a->m_size&#43;&#43;;cout <<"添加成功&#xff01;";system("cls");}}

3.4 测试功能

在主程序中加入”添加联系人“代码&#xff0c;测试功能。

int main()
{int select &#61; 0;//输入你的选择项contact_book arr;//结构体数组定义arr.m_size &#61; 0;while(true){showMenu();cin >> select;switch (select){case 1:// 添加联系人addPreson(&arr);break;case 0://退出通讯录cout <<"欢迎下次使用" <}

效果&#xff1a;

 4、显示联系人

功能&#xff1a; 显示通讯录中所有的联系人及其信息。

4.1 显示联系人函数

void showPerson(contact_book* a)
{if (a->m_size &#61;&#61; 0){cout <<"当前记录为空" <m_size; i&#43;&#43;){cout <<"姓名&#xff1a;" <array[i].name <<"\t" <<"性别&#xff1a;" <array[i].gender <<"\t"<<"年龄&#xff1a;" <array[i].age<<"\t" <<"联系电话&#xff1a;" <array[i].phone_number<<"\t"<<"住址&#xff1a;" <array[i].address <}

4.2 主程序中调用

int main()
{int select &#61; 0;//输入你的选择项contact_book arr;//结构体数组定义arr.m_size &#61; 0;while(true){showMenu();cin >> select;switch (select){case 0://退出通讯录cout <<"欢迎下次使用" <}

效果&#xff1a;

 5 删除联系人

功能&#xff1a;删除指定姓名的联系人

思路&#xff1a;

  1. 判断联系人是否存在
  2. 存在的话删除

5.1 判断联系人是否存在

int chechperson(string name,contact_book* a)
{if (a->m_size &#61;&#61; 0)return -1;else{for (int i &#61; 0; i m_size; i&#43;&#43;){if (name &#61;&#61; a->array[i].name)return i;}return -1;}
}

5.2 删除联系人函数

void deletePerson(contact_book* a)
{string name;cout <<"请输入你想删除的联系人" <> name;int index &#61; chechperson(name, a);if (index &#61;&#61; -1)cout <<"用户不存在"<m_size; i&#43;&#43;){a->array[index] &#61; a->array[index &#43; 1];}a->m_size--;}
}

5.3 主程序中调用

int main()
{int select &#61; 0;//输入你的选择项contact_book arr;//结构体数组定义arr.m_size &#61; 0;while(true){showMenu();cin >> select;switch (select){case 0://退出通讯录cout <<"欢迎下次使用" <}

效果&#xff1a;

 6 查找联系人

功能&#xff1a;查找指定姓名的联系人信息。

void findPerson(contact_book* a)
{string name;cout <<"请输入要查找的联系人&#xff1a;";cin >> name;int i &#61; chechperson(name, a);if (i !&#61; -1){cout <<"姓名&#xff1a;" <array[i].name <<"\t" <<"性别&#xff1a;" <array[i].gender <<"\t"<<"年龄&#xff1a;" <array[i].age <<"\t" <<"联系电话&#xff1a;" <array[i].phone_number <<"\t"<<"住址&#xff1a;" <array[i].address <}

 效果&#xff1a;

7 修改联系人

功能&#xff1a;修改指定姓名联系人的信息

void correctPersor(contact_book* a)
{//先找到有没有这个人cout <<"请输入想修改的联系人&#xff1a;";string name;cin >> name;int i &#61; chechperson(name, a);if (i!&#61;-1){cout <<"姓名&#xff1a;" <array[i].name <<"\t" <<"性别&#xff1a;" <array[i].gender <<"\t"<<"年龄&#xff1a;" <array[i].age <<"\t" <<"联系电话&#xff1a;" <array[i].phone_number <<"\t"<<"住址&#xff1a;" <array[i].address <> a->array[i].name;cout <<"性别&#xff1a;";cin >> gender;while (gender !&#61; "男" && gender !&#61; "女"){cout <<"性别输入有误&#xff0c;请重新输入" <> gender;}a->array[i].gender &#61; gender;cout <<"年龄&#xff1a;";cin >> a->array[i].age;cout <<"联系电话&#xff1a;";cin >> a->array[i].phone_number;cout <<"住址&#xff1a;";cin >> a->array[i].address;cout <<"修改成功&#xff01;";}elsecout <<"查找不到此联系人" <}

效果&#xff1a;

 8 清空联系人

功能&#xff1a;把所有的联系人清空

思路&#xff1a;把通讯录数组的容量置为0

void clearPerson(contact_book* a)
{a->m_size &#61; 0;cout <<"清除成功";system("cls");
}

效果&#xff1a;




推荐阅读
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 本文介绍了解决二叉树层序创建问题的方法。通过使用队列结构体和二叉树结构体,实现了入队和出队操作,并提供了判断队列是否为空的函数。详细介绍了解决该问题的步骤和流程。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • 本文讨论了clone的fork与pthread_create创建线程的不同之处。进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合。在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性。但是二者之间的通讯需要通过专门的通讯机制,另外通过fork创建子进程系统开销很大。因此,在某些情况下,使用clone或pthread_create创建线程可能更加高效。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
  • Go语言实现堆排序的详细教程
    本文主要介绍了Go语言实现堆排序的详细教程,包括大根堆的定义和完全二叉树的概念。通过图解和算法描述,详细介绍了堆排序的实现过程。堆排序是一种效率很高的排序算法,时间复杂度为O(nlgn)。阅读本文大约需要15分钟。 ... [详细]
  • 李逍遥寻找仙药的迷阵之旅
    本文讲述了少年李逍遥为了救治婶婶的病情,前往仙灵岛寻找仙药的故事。他需要穿越一个由M×N个方格组成的迷阵,有些方格内有怪物,有些方格是安全的。李逍遥需要避开有怪物的方格,并经过最少的方格,找到仙药。在寻找的过程中,他还会遇到神秘人物。本文提供了一个迷阵样例及李逍遥找到仙药的路线。 ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • 本文介绍了使用哈夫曼树实现文件压缩和解压的方法。首先对数据结构课程设计中的代码进行了分析,包括使用时间调用、常量定义和统计文件中各个字符时相关的结构体。然后讨论了哈夫曼树的实现原理和算法。最后介绍了文件压缩和解压的具体步骤,包括字符统计、构建哈夫曼树、生成编码表、编码和解码过程。通过实例演示了文件压缩和解压的效果。本文的内容对于理解哈夫曼树的实现原理和应用具有一定的参考价值。 ... [详细]
  • 本文介绍了Codeforces Round #321 (Div. 2)比赛中的问题Kefa and Dishes,通过状压和spfa算法解决了这个问题。给定一个有向图,求在不超过m步的情况下,能获得的最大权值和。点不能重复走。文章详细介绍了问题的题意、解题思路和代码实现。 ... [详细]
author-avatar
402-928
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有