C++实现简单的通讯录管理系统

 更新时间:2022年06月20日 09:19:15   作者:石先森很疯狂  
这篇文章主要为大家详细介绍了C++实现简单的通讯录管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C++实现简单的通讯录管理系统的具体代码,供大家参考,具体内容如下

案例描述:

通讯录是一个可以记录亲人、好友信息的工具。
本教程主要利用C++来实现一个通讯录管理系统
系统中需要实现的功能如下:

  • 添加联系人:向通讯录中添加新人,信息包括(姓名、性别、年龄、联系电话、家庭住址)最多记录1000人
  • 显示联系人:显示通讯录中所有联系人信息
  • 删除联系人:按照姓名进行删除指定联系人
  • 查找联系人:按照姓名查看指定联系人信息
  • 修改联系人:按照姓名重新修改指定联系人
  • 清空联系人:清空通讯录中所有信息
  • 退出通讯录:退出当前使用的通讯录
#include<iostream>
#include<string>
using namespace std;
#define MAX  1000    //通讯录总人数,可以修改

//联系人信息结构体
struct Person
{
    string name;
    string sex;
    int  age;
    int number;
    string address;
};
//通讯录结构体
struct addressbook
{
    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;
}

//查找联系人
int findPerson(addressbook* abs, string name) {
    //-1代表不存在该联系人
    int j = -1;
    for (int i = 0; i < abs->m_Size; i++) {
        if (abs->personArray[i].name == name) {
            cout << "姓名:" << abs->personArray[i].name << "    "
                << "性别:" << abs->personArray[i].sex << "    "
                << "年龄:" << abs->personArray[i].age << "    "
                << "联系电话:" << abs->personArray[i].number << "    "
                << "家庭住址:" << abs->personArray[i].address << endl;
            //获得已存在联系人的下标
            j = i;
        }
    }
    return j;
}

//添加联系人
void addPerson(addressbook* abs, string name) {
    int sex = 0;
    int age;
    int number;
    string address;

    abs->personArray[abs->m_Size].name = name;
    cout << "请输入性别:" << endl;
    cout << "1 -- 男" << endl;
    cout << "2 -- 女" << endl;
    //性别
    while (true)
    {
        cin >> sex;
        if (sex == 1 || sex == 2)
        {
            if (sex == 1) {
                abs->personArray[abs->m_Size].sex = "男";
                break;
            }
            else
            {
                abs->personArray[abs->m_Size].sex = "女";
                break;
            }
        }
        cout << "输入有误,请重新输入";
    }

    //年龄
    cout << "请输入年龄:" << endl;
    cin >> age;
    abs->personArray[abs->m_Size].age = age;

    //联系电话
    cout << "请输入联系电话:" << endl;
    cin >> number;
    abs->personArray[abs->m_Size].number = number;

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

    //更新通讯录人数
    abs->m_Size++;
    cout << "添加成功" << endl;
    system("pause");
    //执行清屏操作
    system("cls");
}

//判断联系人受否存在
void existsPerson(addressbook* abs, string name) {
    //判断通讯录是否已满
    if (abs->m_Size == 1000) {
        cout << "通讯录已满,不能添加联系人!" << endl;
    }
    //未满,则判断联系人是否已存在
    else
    {  //判断用户输入的联系人是否存在
        int p = findPerson(abs, name);
        //不存在执行添加联系人操作
        if (p == -1) {
            addPerson(abs, name);
        }
        else
        {  //若存在,则输出联系人信息,并询问用户是否继续添加
            int i = p;
            cout << "姓名:" << abs->personArray[i].name << "    "
                << "性别:" << abs->personArray[i].sex << "    "
                << "年龄:" << abs->personArray[i].age << "    "
                << "联系电话:" << abs->personArray[i].address << "    "
                << "家庭住址:" << abs->personArray[i].address << endl;
            cout << "联系人已存在! " << endl;
            system("pause");
            //执行清屏操作
            system("cls");
        }
    }
}

//删除联系人
void deletePerson(addressbook* abs) {
    string name;
    cout << "请输入联系人姓名" << endl;
    cin >> name;
    //判断用户输入的联系人是否存在
    int p = findPerson(abs, name);
    if (p != -1) {
        //进行删除联系人操作
        for (int i = p; i < abs->m_Size; i++) {
            abs->personArray[i] = abs->personArray[i + 1];
        }
        //更新通讯录
        abs->m_Size--;
        cout << "删除成功!" << endl;
    }
    else
    {
        cout << "查无此人!" << endl;
    }
    system("pause");
    //执行清屏操作
    system("cls");
}

//显示联系人
void showPerson(addressbook* abs) {
    if (abs->m_Size == 0)
    {
        cout << "当前记录为空" << endl;
    }
    else
    {
        for (int i = 0; i < abs->m_Size; i++)
        {
            cout << "姓名:" << abs->personArray[i].name << "\t";
            cout << "性别:" << abs->personArray[i].sex << "\t";
            cout << "年龄:" << abs->personArray[i].age << "\t";
            cout << "电话:" << abs->personArray[i].number << "\t";
            cout << "住址:" << abs->personArray[i].address << endl;
        }
    }
    system("pause");
    system("cls");
}

//修改联系人
void changePerson(addressbook* abs) {
    string name;
    int sex = 0;
    int age;
    int number;
    string address;

    cout << "请输入联系人姓名:" << endl;
    cin >> name;
    //判断用户输入的联系人是否存在
    int  p = findPerson(abs, name);
    if (p != -1) {
        cout << "请输入联系人姓名:" << endl;
        cin >> name;
        abs->personArray[p].name = name;
        cout << "请输入性别:" << endl;
        cout << "1 -- 男" << endl;
        cout << "2 -- 女" << endl;
        //性别
        while (true)
        {
            cin >> sex;
            if (sex == 1 || sex == 2)
            {
                if (sex == 1) {
                    abs->personArray[p].sex = "男";
                    break;
                }
                else
                {
                    abs->personArray[p].sex = "女";
                    break;
                }
            }
            cout << "输入有误,请重新输入";
        }

        //年龄
        cout << "请输入年龄:" << endl;
        cin >> age;
        abs->personArray[p].age = age;

        //联系电话
        cout << "请输入联系电话:" << endl;
        cin >> number;
        abs->personArray[p].number = number;

        //家庭住址
        cout << "请输入家庭住址:" << endl;

        cin >> address;
        abs->personArray[p].address = address;

        cout << "修改成功" << endl;
        system("pause");
        //执行清屏操作
        system("cls");
    }
    else
    {
        cout << "该联系人不存在!" << endl;
        system("pause");
        //执行清屏操作
        system("cls");
    }
}
//清空联系人
void empty(addressbook* abs) {
    abs->m_Size = 0;
    cout << "通讯录已清空" << endl;
    system("pause");
    system("cls");
}

int main() {
    //初始化通讯录
    addressbook abs;
    //初始化通讯录人数为0
    abs.m_Size = 0;

    int flag = true;
    int key = 0;
    string name;
    while (true)
    {
        showMenu();
        cout << "请输入要操作的功能" << endl;
        cin >> key;
        switch (key)
        {
        case 1:
            //先判断判断通讯录是否已满,在判断联系人是否已存在
            //最后进行联系人添加操作addPerson(addressbook *abs)
            cout << "请输入联系人姓名" << endl;
            cin >> name;
            existsPerson(&abs, name);
            break;
        case 2:
            showPerson(&abs);
            break;
        case 3:
            deletePerson(&abs);
            break;
        case 4:
            cout << "请输入联系人姓名" << endl;
            cin >> name;
            findPerson(&abs, name);
            system("pause");
            //执行清屏操作
            system("cls");
            break;
        case 5:
            changePerson(&abs);
            break;
        case 6:
            empty(&abs);
            break;
        case 0:
            cout << "欢迎下次使用!" << endl;
            system("pause");
            return 0;
            break;
        default:
            cout << "请输入正确的选项序号:" << endl;
            break;
        }
    }

    system("pause");

    return 0;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C++中char[]能修改char*却不行

    C++中char[]能修改char*却不行

    本文主要介绍了C++中char[]能修改char*却不行,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • 如何统计在一篇文章中某个单词出现了几次,以及第一次出现的位置

    如何统计在一篇文章中某个单词出现了几次,以及第一次出现的位置

    本文的主要内容就是统计某个单词在一篇文章中出现了几次,以及第一次出现的位置,需要的朋友可以参考下
    2015-08-08
  • cmake 学习笔记

    cmake 学习笔记

    这篇文章主要介绍了作者学习cmake 的相关资料与心得,有需要的小伙伴可以参考下
    2017-07-07
  • C++深浅拷贝和写时拷贝图文详解

    C++深浅拷贝和写时拷贝图文详解

    这篇文章主要给大家介绍了关于C++深浅拷贝和写时拷贝的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • 一文详解Qt中的对象树机制

    一文详解Qt中的对象树机制

    Qt提供了对象树机制,能够自动、有效的组织和管理继承自QObject的Qt对象。这篇文章将通过一些示例为大家介绍一下Qt中对象树机制的使用,需要的可以参考一下
    2023-03-03
  • C++详解哈夫曼树的概念与实现步骤

    C++详解哈夫曼树的概念与实现步骤

    给定N个权值作为N个叶子结点,构造一棵二叉树,若该树的带权路径长度达到最小,称这样的二叉树为最优二叉树,也称为哈夫曼树(Huffman Tree)。哈夫曼树是带权路径长度最短的树,权值较大的结点离根较近
    2022-04-04
  • C语言实现常用字符串库函数(推荐)

    C语言实现常用字符串库函数(推荐)

    这篇文章主要介绍了C语言实现常用字符串库函数,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-11-11
  • c++primer类详解

    c++primer类详解

    今天小编就为大家分享一篇关于C++Primer中变量和基本类型的文章,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2021-09-09
  • opencv图片的任意角度旋转实现示例

    opencv图片的任意角度旋转实现示例

    这篇博客将介绍如何使用OpenCV旋转图像任意角度,实现各个角度的旋转,具有一定的参考价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-06-06
  • C语言数据存储归类介绍

    C语言数据存储归类介绍

    使用编程语言进行编程时,需要用到各种变量来存储各种信息。变量保留的是它所存储的值的内存位置。这意味着,当您创建一个变量时,就会在内存中保留一些空间。您可能需要存储各种数据类型的信息,操作系统会根据变量的数据类型,来分配内存和决定在保留内存中存储什么
    2022-08-08

最新评论