通讯录管理系统简单实现

1.功能介绍

     今天我们要实现的通讯录管理系统主要有7项功能:添加联系人,显示联系人,删除联系人,查找联系人,修改联系人,清空联系人,退出通讯录

2.功能实现

2.1创建联系人结构体 通讯录结构体

     一个联系人应该包含姓名、性别、年龄、电话号码、家庭住址信息,我们要把这些信息封装成一个结构体;同时一个通讯录应该包含联系人结构体显示信息和联系人的数量,则有以下代码:

//创建联系人结构体
typedef struct Person
{
    string name;//姓名
    int sex;//1男 2女
    int age;//年龄
    string phone;//电话号码
    string address;//家庭住址
}Person;

//创建通讯录结构体 主要包括存储联系人的数组和联系人数量
typedef struct addressBook
{
    Person personArray[1000];//通讯录存储的最大联系人数量为1000,personArray数组每个元素都是一个Person结构体
    int size;//联系人数量
}addressBook;

2.2 创建菜单

     一个好的通讯录管理系统,我们让使用者知道它输入什么能执行怎样的操作,所以我们应该创建一个操作提示的菜单,方便进行操作,代码如下:

//创建菜单
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;
}

     效果展示:

2.3 添加联系人

     我们首先需要判断通讯录是否已满,如果满了就无法添加;没满我们就将姓名、性别、年龄、电话号码、家庭住址信息填入,特别注意性别和年龄,当使用者输入性别时,只有两种选择,如果使用者输入其他数据,我们就要提示他数据有误,同时重新进行输入。同理年龄也是如此,没有人是0岁,现在也没有人能活到150岁,所以如果输入的数据不在这个区间内,我们也要进行提示,同时重新输入。


//添加联系人
void addPerson(addressBook* ans)
{
    if (ans->size == 1000)
    {
        cout << "通讯录已满,无法添加" << endl;
    }
    else
    {
       //添加联系人

        //姓名
        string name;
        cout << "请输入姓名:" << endl;
        cin >> name;
        ans->personArray[ans->size].name = name;

        //性别
        cout << "请输入性别:" << endl;
        cout << "1---男" << endl;
        cout << "2---女" << endl;
        int sex = 0;
       
        while (true)
        {
            cin >> sex;
            if (sex == 1 || sex == 2)
            {
                ans->personArray[ans->size].sex = sex;
                break;
            }
            cout << "您输入的数据有误,请重新输入" << endl;
        }

        //年龄
        cout << "请输入年龄:" << endl;
        int age = 0;
        while (true)
        {
            cin >> age;
            if (sex>0&&age<=150)
            {
                ans->personArray[ans->size].age= age;
                break;
            }
            cout << "您输入的数据有误,请重新输入" << endl;
        }
    }

        //电话
        cout << "请输入联系电话:" << endl;
        string phone;
        cin >> phone;
        ans->personArray[ans->size].phone = phone;

        //家庭住址
        cout << "请输入家庭住址:" << endl;
        string address;
        cin >> address;
        ans->personArray[ans->size].address = address;

        //更新人数
        ans->size++;

        cout << "添加成功!" << endl;

        system("pause");//按任意键继续
        system("cls");//清屏操作
}

     这里有两端代码system("pause")和system("cls"),一个提示我们按任意键进行下一步操作,一个进行清屏的操作,让界面更加简洁,就像这样:

 

 2.4 显示联系人

     当我们想查看通讯录有哪些联系人时,就执行这个操作,先判断通讯录是否为空,如果为空就进行提示,否则输出联系人的信息,代码如下:

//显示联系人
void showPerson(addressBook* ans)
{
    //判断通讯录人数是否为0
    if (ans->size == 0)
    {
        cout << "通讯录为空,没有联系人" << endl;
    }
    else
    {
        for (int i = 0; i <ans->size; i++)
        {
            printf("第%d个联系人\n", i+1);
            cout << "姓名:" << ans->personArray[i].name << "\t";
            cout << "性别:" << (ans->personArray[i].sex==1?"男":"女") << "\t";
            cout << "年龄:" << ans->personArray[i].age << "\t";
            cout << "电话号码:" << ans->personArray[i].phone << "\t";
            cout << "家庭住址:" << ans->personArray[i].address << endl;;

        }
    }
    system("pause");//按任意键继续
    system("cls");//清屏
}

     效果展示:在此之前我已经添加了两位联系人

2.4 删除联系人

     如果我们不想有某个人的联系方式,想把它删了,我们需要先查找是否存在这个联系人,如果都没有,那更好,如果有,那就把他删了!如何删除呢?就是用后面的联系人覆盖掉前面的,最后ans->size--即可。

//判断某个联系人是否存在
int isExist(addressBook* ans, string name)
{
    for (int i = 0; i < ans->size; i++)
    {
        if (ans->personArray[i], name == name)
        {
            return i;
        }
    }
    return -1;
}
//删除联系人
void deletePerson(addressBook* ans)
{
    cout << "请输入您要删除的联系人" << endl;
    string name;
    cin >> name;
    int ret=isExist(ans, name);
    if (ret == -1)
    {
        cout << "没有这个联系人" << endl;
    }
    else
    {
        cout << "找到了这个联系人" << endl;
    }
    for (int i = ret; i < ans->size; i++)
    {
        ans->personArray[i] = ans->personArray[i + 1];
    }
    ans->size--;
    cout << "删除成功" << endl;
    system("pause");
    system("cls");

2.5 查找联系人

     我们想看某个联系人的信息,先判断是否存在,存在就可以执行这个操作

//判断某个联系人是否存在
int isExist(addressBook* ans, string name)
{
    for (int i = 0; i < ans->size; i++)
    {
        if (ans->personArray[i], name == name)
        {
            return i;
        }
    }
    return -1;
}

//查找联系人
void  findPerson(addressBook* ans)
{
    cout << "请输入您要查找的联系人的姓名:" << endl;
    string name;
    cin >> name;
    int ret = isExist(ans, name);
    if (ret !=-1)
    {
        cout << "找到了这个联系人" << endl;
    }
    else
    {
        cout << "没有这个联系人" << endl;
    }
    system("pause");
    system("cls");
}

2.6 修改联系人

     如果某个联系人的信息需要修改,那我们首先要判断是否存在这个联系人是否存在,存在我们才能进行修改

//修改联系人
void modifyPerson(addressBook* ans)
{
    cout << "请输入您要修改的联系人的姓名" << endl;
    string name;
    cin >> name;
    int ret = isExist(ans, name);
    if (ret != -1)
    {
        //姓名
        string name;
        cout << "请输入姓名:" << endl;
        cin >> name;
        ans->personArray[ret].name = name;

        //性别
        cout << "请输入性别:" << endl;
        cout << "1---男" << endl;
        cout << "2---女" << endl;
        int sex = 0;

        while (true)
        {
            cin >> sex;
            if (sex == 1 || sex == 2)
            {
                ans->personArray[ret].sex = sex;
                break;
            }
            cout << "您输入的数据有误,请重新输入" << endl;
        }

        //年龄
        cout << "请输入年龄:" << endl;
        int age = 0;
        while (true)
        {
            cin >> age;
            if (sex > 0 && age <= 150)
            {
                ans->personArray[ret].age = age;
                break;
            }
            cout << "您输入的数据有误,请重新输入" << endl;
        }
    

       //电话
       cout << "请输入联系电话:" << endl;
       string phone;
       cin >> phone;
       ans->personArray[ret].phone = phone;

      //家庭住址
      cout << "请输入家庭住址:" << endl;
      string address;
      cin >> address;
      ans->personArray[ret].address = address;
      cout<<"修改成功"<<endl;
      }
      else
      {
        cout << "没有这个联系人" << endl;
      }
      system("pause");
      system("cls");
}

     效果展示:


 

2.7 清空联系人

     就是让ans->size=0即可。

//清空联系人
void clearPerson(addressBook* ans)
{
    ans->size = 0;
    cout << "通讯录已清空" << endl;
    system("pause");
    system("cls");

     效果展示:

3.主函数实现

     我们要保证输入数字能够执行操作,这很显然要使用switch语句,每次执行完一次操作之后能继续进行下一步操作,那就必须存在循环,还要保证我们能够退出通讯录,那就当输入0时return 0即可。

int main()
{ 
    //创建通讯录结构体变量
    addressBook ans;
    ans.size = 0;
    int select = 0;//创建用户选择的操作变量
    while (true)
    {
        //菜单调用
        showMenu();
        cin >> select;
        switch (select)
        {
        case 1:    //添加联系人
            addPerson(&ans);
            break;
        case 2:    //显示联系人
            showPerson(&ans);
            break;
        case 3:    //删除联系人
            deletePerson(&ans);
            break;
        case 4:    //查找联系人
            findPerson(&ans);
            break;
        case 5:    //修改联系人
            modifyPerson(&ans);
            break;
        case 6:    //清空联系人
            clearPerson(&ans);
            break;
        case 0:   //退出通讯录
            cout << "欢迎您下次使用" << endl;
            return 0;//结束这个程序
            break;
        default:
            break;
        }
    }
}

4.完整代码

#include <iostream>
#include<string>
using namespace std;
//一个通讯录应该具有以下的功能
//添加联系人,显示联系人,删除联系人,查找联系人,修改联系人,清空联系人,退出通讯录

//创建联系人结构体
typedef struct Person
{
    string name;//姓名
    int sex;//1男 2女
    int age;//年龄
    string phone;//电话号码
    string address;//家庭住址
}Person;

//创建通讯录结构体 主要包括存储联系人的数组和联系人数量
typedef struct addressBook
{
    Person personArray[1000];//通讯录存储的最大联系人数量为1000,personArray数组每个元素都是一个Person结构体
    int size;//联系人数量
}addressBook;

//创建菜单
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;
}

//添加联系人
void addPerson(addressBook* ans)
{
    if (ans->size == 1000)
    {
        cout << "通讯录已满,无法添加" << endl;
    }
    else
    {
       //添加联系人

        //姓名
        string name;
        cout << "请输入姓名:" << endl;
        cin >> name;
        ans->personArray[ans->size].name = name;

        //性别
        cout << "请输入性别:" << endl;
        cout << "1---男" << endl;
        cout << "2---女" << endl;
        int sex = 0;
       
        while (true)
        {
            cin >> sex;
            if (sex == 1 || sex == 2)
            {
                ans->personArray[ans->size].sex = sex;
                break;
            }
            cout << "您输入的数据有误,请重新输入" << endl;
        }

        //年龄
        cout << "请输入年龄:" << endl;
        int age = 0;
        while (true)
        {
            cin >> age;
            if (sex>0&&age<=150)
            {
                ans->personArray[ans->size].age= age;
                break;
            }
            cout << "您输入的数据有误,请重新输入" << endl;
        }
    }

        //电话
        cout << "请输入联系电话:" << endl;
        string phone;
        cin >> phone;
        ans->personArray[ans->size].phone = phone;

        //家庭住址
        cout << "请输入家庭住址:" << endl;
        string address;
        cin >> address;
        ans->personArray[ans->size].address = address;

        //更新人数
        ans->size++;

        cout << "添加成功!" << endl;

        system("pause");//按任意键继续
        system("cls");//清屏操作
}

//显示联系人
void showPerson(addressBook* ans)
{
    //判断通讯录人数是否为0
    if (ans->size == 0)
    {
        cout << "通讯录为空,没有联系人" << endl;
    }
    else
    {
        for (int i = 0; i <ans->size; i++)
        {
            printf("第%d个联系人\n", i+1);
            cout << "姓名:" << ans->personArray[i].name << "\t";
            cout << "性别:" << (ans->personArray[i].sex==1?"男":"女") << "\t";
            cout << "年龄:" << ans->personArray[i].age << "\t";
            cout << "电话号码:" << ans->personArray[i].phone << "\t";
            cout << "家庭住址:" << ans->personArray[i].address << endl;;

        }
    }
    system("pause");//按任意键继续
    system("cls");//清屏
}
//判断某个联系人是否存在
int isExist(addressBook* ans, string name)
{
    for (int i = 0; i < ans->size; i++)
    {
        if (ans->personArray[i], name == name)
        {
            return i;
        }
    }
    return -1;
}

//查找联系人
void  findPerson(addressBook* ans)
{
    cout << "请输入您要查找的联系人的姓名:" << endl;
    string name;
    cin >> name;
    int ret = isExist(ans, name);
    if (ret !=-1)
    {
        cout << "找到了这个联系人" << endl;
    }
    else
    {
        cout << "没有这个联系人" << endl;
    }
    system("pause");
    system("cls");
}

//删除联系人
void deletePerson(addressBook* ans)
{
    cout << "请输入您要删除的联系人" << endl;
    string name;
    cin >> name;
    int ret=isExist(ans, name);
    if (ret != -1)
    {
        for (int i = ret; i < ans->size; i++)
        {
            ans->personArray[i] = ans->personArray[i + 1];
        }
        ans->size--;
        cout << "删除成功" << endl;
    }
    else
    {
        cout << "没有这个联系人" << endl;
    }
    system("pause");
    system("cls");
}

//修改联系人
void modifyPerson(addressBook* ans)
{
    cout << "请输入您要修改的联系人的姓名" << endl;
    string name;
    cin >> name;
    int ret = isExist(ans, name);
    if (ret != -1)
    {
        //姓名
        string name;
        cout << "请输入姓名:" << endl;
        cin >> name;
        ans->personArray[ret].name = name;

        //性别
        cout << "请输入性别:" << endl;
        cout << "1---男" << endl;
        cout << "2---女" << endl;
        int sex = 0;

        while (true)
        {
            cin >> sex;
            if (sex == 1 || sex == 2)
            {
                ans->personArray[ret].sex = sex;
                break;
            }
            cout << "您输入的数据有误,请重新输入" << endl;
        }

        //年龄
        cout << "请输入年龄:" << endl;
        int age = 0;
        while (true)
        {
            cin >> age;
            if (sex > 0 && age <= 150)
            {
                ans->personArray[ret].age = age;
                break;
            }
            cout << "您输入的数据有误,请重新输入" << endl;
        }
    

    //电话
    cout << "请输入联系电话:" << endl;
    string phone;
    cin >> phone;
    ans->personArray[ret].phone = phone;

    //家庭住址
    cout << "请输入家庭住址:" << endl;
    string address;
    cin >> address;
    ans->personArray[ret].address = address;
    cout << "修改成功" << endl;
    }
    else
    {
        cout << "没有这个联系人" << endl;
    }
    system("pause");
    system("cls");
}

//清空联系人
void clearPerson(addressBook* ans)
{
    ans->size = 0;
    cout << "通讯录已清空" << endl;
    system("pause");
    system("cls");
}
int main()
{ 
    //创建通讯录结构体变量
    addressBook ans;
    ans.size = 0;
    int select = 0;//创建用户选择的操作变量
    while (true)
    {
        //菜单调用
        showMenu();
        cin >> select;
        switch (select)
        {
        case 1:    //添加联系人
            addPerson(&ans);
            break;
        case 2:    //显示联系人
            showPerson(&ans);
            break;
        case 3:    //删除联系人
            deletePerson(&ans);
            break;
        case 4:    //查找联系人
            findPerson(&ans);
            break;
        case 5:    //修改联系人
            modifyPerson(&ans);
            break;
        case 6:    //清空联系人
            clearPerson(&ans);
            break;
        case 0:   //退出通讯录
            cout << "欢迎您下次使用" << endl;
            return 0;//结束这个程序
            break;
        default:
            break;
        }
    }
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

linux 中 ext2文件系统实现

ext2文件系统结构 图片的svg下载链接&#xff08;图中关于buffer的部分&#xff0c;上下两部分是重复的&#xff0c;是从不同维度下看的buffer结构&#xff09; linux内核本身不提供ext2文件系统的格式化功能&#xff0c;可以参考busybox中对mkfs.ext2的实现&#xff08;mkfs.…

【数据结构】顺序表与单链表的增删查改

文章目录 前言顺序表增删查改顺序表的定义与初始化增删查改操作测试代码完整代码 单链表的增删查改数据结构定义动态申请节点单链表的尾插和头插单链表的尾删和头删单链表的查找单链表的插入和删除销毁链表测试代码完整代码 总结 前言 在计算机编程领域&#xff0c;数据结构是…

安全运维是做什么的,主要工作内容是什么

安全运维&#xff0c;简称SecOps&#xff0c;是一种集成安全措施和流程到信息技术运维的实践。它的目的是确保在日常运维活动中&#xff0c;如网络管理、系统维护、软件更新等&#xff0c;均考虑并融入安全策略。安全运维的核心是实现安全和运维团队的密切协作&#xff0c;以快…

前端map标签(创建热点区域或是点击图片指定区域跳转对应链接))

前言 点击整张图片的某一部分,可以实现自定义跳转或者一些事件 利用img和map和area标签实现 先来看下实现 https://www.w3cschool.cn/tryrun/showhtml/tryhtml_areamap <img src"/statics/images/course/planets.gif" width"145" height"126&…

条件覆盖和条件组合覆盖测试设计-实验八例题

目录 条件覆盖 判定-条件覆盖 条件组合覆盖 实验内容&#xff1a; 以银行内部转账为实例&#xff0c;针对内部转账业务逻辑代码进行分析&#xff0c;运用条件覆盖和条件组合覆盖进行测试用例设计。 实验过程&#xff1a; 条件覆盖 条件覆盖&#xff08;Condition Cover…

java中XML格式转换

之前很少用xml格式&#xff0c;但是有些老系统还是需要使用xml格式进行对接&#xff0c;所以干脆总结一下&#xff0c;方便以后使用。 关于xml: 即可扩展标记语言&#xff0c;xml是互联网数据传输的重要工具&#xff0c;它可以跨越互联网任何的平台&#xff0c;不受编程语言和操…

Word中插入mathtype的行内公式显示不全,设置行距,最小值

Word中插入mathtype的行内公式显示不全 如下图&#xff1a;公式上下被遮住 解决方式&#xff1a; 设置所在段落的行距&#xff1a;最小值--xx磅。同时取消勾选 “如果定义了文档网格&#xff0c;则对齐到网格” 处理后效果&#xff1a;

Flash芯片W25Q系列驱动注意事项以及跨页读写操作

一、硬件 二、W25Q64简介与API函数 1) W25Q有很多系列&#xff0c;其区别就是存储容量不一样 以我现在使用的举例W25Q64 64指的是64Mbit&#xff0c;不是64M字节要区分清楚 64Mbit 8Mbyte,所以总的容量能存储8MByte 2) W25q64的存储分为块、扇区、页 一页&#xff1…

人类偏好导向:DPO技术重塑SDXL-1.0图像生成

引言 在AI领域&#xff0c;适应和理解人类偏好一直是技术发展的重要方向。斯坦福大学研究团队最近提出的Diffusion-DPO方法&#xff0c;旨在将这一理念应用于图像生成模型&#xff0c;特别是在文本到图像的转换领域。 Huggingface模型下载: https://huggingface.co/mhdang/ A…

windows搭建MySQL 8.25主从配置

1.本次搭建的版本 mysql-8.0.25-win-x64 2.在解压完成后的文件内并没有对应的my.ini的配置文件这个my.ini是需要的主配置文件需要自行创建。 注&#xff1a;安装路径及数据存放路径需根据实际安装情况进行修改&#xff08;其它配置信息可结合实际情况进行修改&#xff09; 3.在…

【Vue】响应式中数组的特殊处理

Vue 响应式中对数组的处理 前两节的内容&#xff1a; Vue 数据劫持 Vue 响应式初步 0. 为什么需要对数组特殊处理&#xff1f; 在响应式初步那一篇文章的最后&#xff0c;我们提到过&#xff0c;需要对数组进行特殊的处理&#xff0c;为什么&#xff1f; 如果仍然用我们之…

vue3(六)-基础入门之自定义组件与插槽、ref通信

一、全局组件 html: <div id"app"><mytemplace></mytemplace> </div>javascript: <script>const { createApp } Vueconst app createApp({})app.component(mytemplace, {template: <div><button>返回</button>…

Resnet

是什么样的原因导致更深的网络导致的训练效果更差呢&#xff1f; 梯度消失和梯度爆炸 随着网络层数的不断加深&#xff0c;梯度消失和梯度爆炸的现象会越来越明显&#xff0c; 梯度消失&#xff1a;假设每一层的误差梯度是一个小于1的数&#xff0c;那么在我们反向传播过程中…

<软考高项备考>《论文专题 - 26 整合管理(4) 》

6 过程5-监控项目工作 6.1 问题 4W1H过程1-制定项目章程做什么跟踪、审查和报告整体项目进展&#xff0c;以实现项目管理计划中确定的绩效目标的过程&#xff1b;作用&#xff1a;①让干系人了解项目的当前状态并认可为处理绩效问题而采取的行动;②通过成本和进度预测&#x…

Docker 高级网络 - 自定义网桥实现容器间通信

目录 一、容器间容通信 1.1、解释 1.2、网络相关操作指令 1.2.1、查看 docker 的网络列表 1.2.2、创建网络自定义桥 1.2.3、删除某一个网络 1.2.4、查看某一个网络细节 1.2.5、运行多个容器在指定的网络中 一、容器间容通信 1.1、解释 简单来讲就是&#xff1a;容器间通…

华为Auth-HTTP服务器任意文件读取漏洞

华为Auth-Http Server 1.0存在任意文件读取&#xff0c;攻击者可通过该漏洞读取任意文件。 1.漏洞级别 高危 2.漏洞搜索 fofa server"Huawei Auth-Http Server 1.0"3.漏洞复现 构造 GET /umweb/passwd HTTP/1.1 Host: User-Agent: Mozilla/5.0 (Macintosh; I…

APP开发详解:数字药店系统源码

数字药店系统的兴起&#xff0c;不仅为消费者提供了更加便捷的购药体验&#xff0c;也为药店管理和药品销售带来了全新的机遇。 一、明确系统的基本功能&#xff1a; 1.用户注册与登录 2.药品浏览与搜索 3.购物车与结算。 4.在线支付与订单管理 二、开发环境与技术栈选择 …

blackbox黑盒监控部署(k8s内)tensuns专用

一、前言 部署在k8s中需要用到deployment、configmap、service服务 二、部署 创建存放yaml的目录 mkdir /opt/blackbox-exporter && cd /opt/blackbox-exporter 编辑blackbox配置文件&#xff0c;使用configmap挂在这 vi configmap.yaml apiVersion: v1 kind: Confi…

c语言-表达式求值

目录 前言一、隐式类型转换1.1 整型提升 二、算术转换三、操作符的属性四、问题表达式总结 前言 表达式求值的顺序一部分由操作符的优先级和结合性决定。 有些表达式的操作数在求值的过程中可能需要转换为其他类型 一、隐式类型转换 隐式类型转换是在编译器自动进行的类型转换…

TYPE C 接口知识

1、Type C 概述 Type-C口有4对TX/RX分线&#xff0c;2对USBD/D-&#xff0c;一对SBU&#xff0c;2个CC&#xff0c;另外还有4个VBUS和4个地线。 当Type-C接口仅用作传输DP信号时&#xff0c;则可利用4对TX/RX&#xff0c;从而实现4Lane传输&#xff0c;这种模式称为DPonly模式…