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++ 中重载和运算符重载加号实现矩阵相加实例代码

    C++ 中重载和运算符重载加号实现矩阵相加实例代码

    这篇文章主要介绍了C++ 中重载和运算符重载加号实现矩阵相加实例代码的相关资料,需要的朋友可以参考下
    2017-03-03
  • C++ AVL树插入新节点后的四种调整情况梳理介绍

    C++ AVL树插入新节点后的四种调整情况梳理介绍

    AVL树是高度平衡的而二叉树,它的特点是AVL树中任何节点的两个子树的高度最大差别为1,本文主要给大家介绍了C++如何实现AVL树,需要的朋友可以参考下
    2022-08-08
  • C++结构体与类的区别详情

    C++结构体与类的区别详情

    这篇文章主要介绍了C++结构体与类的区别,C++中的struct对C中的struct进行了扩充,它已经不再只是一个包含不同数据类型的数据结构了,它已经获取了太多的功能。下面我们一起进入文章俩姐具体内容,需要的朋友也可以参考一下
    2021-11-11
  • c++线程池实现方法

    c++线程池实现方法

    这篇文章主要介绍了c++线程池实现方法,实例分析了C++线程池的原理与相关实现技巧,需要的朋友可以参考下
    2015-06-06
  • 一文总结C++运算符的使用方法

    一文总结C++运算符的使用方法

    这篇文章主要为大家详细总结了C++中运算符的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2023-05-05
  • C++多重继承引发的重复调用问题与解决方法

    C++多重继承引发的重复调用问题与解决方法

    这篇文章主要介绍了C++多重继承引发的重复调用问题与解决方法,结合具体实例形式分析了C++多重调用中的重复调用问题及相应的解决方法,需要的朋友可以参考下
    2018-05-05
  • C++入门教程之内联函数与extern "C"详解

    C++入门教程之内联函数与extern "C"详解

    C++中的内联函数与静态函数静态函数静态函数的定义静态函数又称为内部函数,下面这篇文章主要给大家介绍了关于C++入门教程之内联函数与extern "C"的相关资料,需要的朋友可以参考下
    2023-01-01
  • C语言完全平方整数的判断

    C语言完全平方整数的判断

    大家好,本篇文章主要讲的是C语言完全平方整数的判断,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12
  • C语言编程入门之程序头文件的简要解析

    C语言编程入门之程序头文件的简要解析

    这篇文章主要介绍了C语言编程入门之程序头文件的简要解析,包括头文件重复包含问题等方面的说明,需要的朋友可以参考下
    2015-12-12
  • C++析构函数内部工作机制详解

    C++析构函数内部工作机制详解

    析构函数(Destructor)也是一种特殊的成员函数,没有返回值,不需要程序员显式调用(程序员也没法显式调用),而是在销毁对象时自动执行。构造函数的名字和类名相同,而析构函数的名字是在类名前面加一个~符号
    2023-02-02

最新评论