C++通讯录管理系统
目录
系统需求
通讯录的功能需求如下
- 添加联系人:向通讯录中添加新人,信息包括(姓名、性别、年龄、联系电话、家庭住址)最多记录10000人
- 显示联系人:显示通讯录中所有联系人信息
- 删除联系人:按照姓名进行删除指定联系人
- 查找联系人:按照姓名查看指定联系人的信息
- 修改联系人:按照姓名重新修改指定联系人
- 清空联系人:清空通讯录中所有信息
- 退出通讯录:退出当前使用的通讯录
创建项目
打开vs2022后,点击创建项目,创建c++项目
再创建头文件
菜单功能
// 编写菜单,显示界面
void show_menu() {
cout << "***************************" << endl;
cout << "***** 0、退出通讯录 *****" << endl;
cout << "***** 1、添加联系人 *****" << endl;
cout << "***** 2、显示联系人 *****" << endl;
cout << "***** 3、删除联系人 *****" << endl;
cout << "***** 4、查找联系人 *****" << endl;
cout << "***** 5、修改联系人 *****" << endl;
cout << "***** 6、清空联系人 *****" << endl;
cout << "***************************" << endl;
}
退出功能
实现方法:根据用户的不同选择,进入不同的功能,可以使用switch分支结构,将整个框架进行搭建,当用户选择0的时候。执行退出,选择其他先不做操作,也不会退出程序
int main() {
int choice = 0;
while (true) {
show_menu(); // 调用函数;显示菜单界面
cout << "请选择一个数字(0--6):";
cin >> choice;
// 选择功能
switch (choice) {
case 0: // 0、退出通讯录
cout << "欢迎下次使用!" << endl;
system("pause"); // 退出功能
return 0;
case 1: // 1、添加联系人
break;
case 2: // 2、显示联系人
break;
case 3: // 3、删除联系人
break;
case 4: // 4、查找联系人
break;
case 5: // 5、修改联系人
break;
case 6: // 6、清空联系人
break;
default:
system("cls"); // 清空界面
cout << "input error" << endl;
}
}
}
添加功能
功能描述:实现添加联系人,联系人上限为1000人,联系人包括(姓名、性别、年龄、联系电话、家庭住址)
实现步骤
- 设计联系人结构体
- 设计通讯录结构体
- main函数中创建通讯录
- 封装添加联系人函数
- 测试添加联系人功能
设计联系人结构体
联系人信息包括:姓名、性别、年龄、联系电话、家庭住址
// 联系人的结构体
struct ContactPerson { // 姓名、性别、年龄、联系电话、家庭住址
#include <string>
string name;
int sex; // 1为男、0位女
int age;
int phone;
string address;
};
设计通讯录结构体
// 通讯录的结构体
struct AddressBooks {
#define MAX 1000 // 定义宏常量,做最大数量
// 通讯录的最大容量
struct ContactPerson perArry[MAX];
// 通讯录中当前记录联系人的个数
int size;
};
main函数中创建通讯录
case 1: // 1、添加联系人
addPerson(&abs);
system("cls"); // 清屏
break;
封装函数
// 添加联系人
void addPerson(AddressBooks* abs) {
// 判断通讯录是否已满,如果满了就不再添加
if (abs->size == MAX) {
cout << "通讯录已满,无法添加!";
}
else {
// 添加联系人
cout << "\n请输入姓名:";
cin >> abs->perArry[abs->size].name;
cout << "\n请输入性别:" << "(注意1为男,0为女)";
int sex_nu = 0;
while (true) { // 如果输入有误,重新输入
cin >> sex_nu;
if (sex_nu == 0 || sex_nu == 1) {
abs->perArry[abs->size].sex = sex_nu;
break;
}
else {
cout << "输入错误,请重新输入!" << endl;
}
}
cout << "\n请输入年龄:";
cin >> abs->perArry[abs->size].age;
cout << "\n请输入电话:";
cin >> abs->perArry[abs->size].phone;
cout << "\n请输入地址:";
cin >> abs->perArry[abs->size].address;
abs->size ++;
cout << "\n添加成功" << endl;
system("pause");
}
}
显示功能
功能描述:显示通讯录已有的联系人信息
显示联系人的步骤
- 封装显示联系人函数
- 测试显示联系人功能
封装函数
// 显示联系人
void show(const AddressBooks* abs) { // 设置为只读
if (abs->size == 0) {
cout << "empty address books" << endl;
system("pause");
}
else{
for (int i = 0; i < abs->size; i++) { // 三目运算判断男女
cout << "姓名:" << abs->perArry[i].name << "\t性别:" << (abs->perArry[i].age == 1 ? "男" : "女")<< "\t年龄:" << abs->perArry[i].age << "\t电话:" << abs->perArry[i].phone << "\t地址:" << abs->perArry[i].address << endl;
}
system("pause");
}
}
删除功能
功能描述:按照姓名进行删除指定联系人
删除联系人的步骤
- 封装检测联系人是否存在
- 封装删除联系人信息的函数
- 测试功能
检测联系人信息是否存在
设计思路:删除联系人前,我们需要先判断用户输入的联系人是否存在,如果存在删除,不存在则提示用户没有要删除的联系人
因此,我们可以在吧检测联系人是否存在封装在一个函数中,如果存在,返回联系人在通讯录中的位置,不存在返回-1
// 判断用户是否存在,存在返回具体位置,不存在返回-1
int judge(AddressBooks* abs, string name) {
int index = -1; // 默认为-1
for (int i = 0; i < abs->size; i++) {
// 找到用户输入的姓名,返回i
if (abs->perArry[i].name == name) {
index = i;
}
}
return index;
}
封装删除联系人函数
根据用户输入的联系人判读该通讯录中是否有此人得到索引后,删除此人
// 删除联系人
void del(AddressBooks* abs, int index) {
for (int i = index; i < abs->size; i++) {
// 数据前移
abs->perArry[i] = abs->perArry[i + 1];
}
abs->size--; // 更新数据
cout << "删除成功" << endl;
system("pause");
}
调用函数
case 3: // 3、删除联系人
{ string name;
cout << "请输入要删除的联系人的姓名:";
cin >> name;
if (judge(&abs, name) == -1) {
cout << "没有该联系人!" << endl;
system("pause");
}
else {
del(&abs, judge(&abs, name));
}
system("cls");
break;
}
查找功能
功能描述:按照姓名查找
查找联系人的步骤:
- 封装查找联系人函数
封装函数
判断用户名是否存在,存在则显示,不存在则返回无
// 查找联系人
void find(AddressBooks* abs, int index) {
cout << "姓名:" << abs->perArry[index].name << "\t性别:" << (abs->perArry[index].age == 1 ? "男" : "女") << "\t年龄:" << abs->perArry[index].age << "\t电话:" << abs->perArry[index].phone << "\t地址:" << abs->perArry[index].address << endl;
system("pause");
}
调用函数
case 4: // 4、查找联系人
{ string name;
cout << "请输入要查找的联系人的姓名:";
cin >> name;
if (judge(&abs, name) == -1) {
cout << "没有该联系人!" << endl;
system("pause");
}
else {
find(&abs, judge(&abs, name));
}
system("cls");
break;
}
修改功能
功能描述:按照姓名重新修改指定联系人
修改联系人步骤
- 封装函数
- 调用函数
封装函数
// 修改功能
void change(AddressBooks* abs, int index) {
// 添加联系人
cout << "\n请输入姓名:";
cin >> abs->perArry[index].name;
cout << "\n请输入性别:" << "(注意1为男,0为女)";
int sex_nu = 0;
while (true) { // 如果输入有误,重新输入
cin >> sex_nu;
if (sex_nu == 0 || sex_nu == 1) {
abs->perArry[index].sex = sex_nu;
break;
}
else {
cout << "输入错误,请重新输入!" << endl;
}
}
cout << "\n请输入年龄:";
cin >> abs->perArry[index].age;
cout << "\n请输入电话:";
cin >> abs->perArry[index].phone;
cout << "\n请输入地址:";
cin >> abs->perArry[index].address;
cout << "\n修改成功" << endl;
system("pause");
}
调用函数
case 5: // 5、修改联系人
{ string name;
cout << "请输入要修改的联系人的姓名:";
cin >> name;
if (judge(&abs, name) == -1) {
cout << "没有该联系人!" << endl;
system("pause");
}
else {
change(&abs, judge(&abs, name));
}
system("cls");
break;
}
清空功能
功能描述:清空通讯录中所有信息
逻辑清空
清空联系人实现步骤
- 封装函数
- 调用函数
封装函数
// 清空功能
void clear(AddressBooks* abs) {
abs->size = 0;
cout << "清空完成" << endl;
system("pause");
}
调用函数
case 6: // 6、清空联系人
{cout << "您是否真的要清空全部联系人:(yes/no)" << endl;
while (true) {
string answer;
cin >> answer;
if (answer == "yes") {
clear(&abs);
system("cls");
break;
}
else if (answer == "no") {
cout << "正在取消操作" << endl;
system("cls");
break;
}
else {
cout << "请按照要求输入,输入yes / no";
}
}
break;
}
完全代码
#include <iostream>
#include <string>
using namespace std;
// 联系人的结构体
struct ContactPerson { // 姓名、性别、年龄、联系电话、家庭住址
string name;
int sex; // 1为男、0位女
int age;
string phone;
string address;
};
// 通讯录的结构体
struct AddressBooks {
#define MAX 1000 // 定义宏常量,做最大数量
// 通讯录的最大容量
struct ContactPerson perArry[MAX];
// 通讯录中当前记录联系人的个数
int size;
};
// 编写菜单,显示界面
void show_menu() {
cout << "***************************" << endl;
cout << "***** 0、退出通讯录 *****" << endl;
cout << "***** 1、添加联系人 *****" << endl;
cout << "***** 2、显示联系人 *****" << endl;
cout << "***** 3、删除联系人 *****" << endl;
cout << "***** 4、查找联系人 *****" << endl;
cout << "***** 5、修改联系人 *****" << endl;
cout << "***** 6、清空联系人 *****" << endl;
cout << "***************************" << endl;
}
// 添加联系人
void addPerson(AddressBooks* abs) {
// 判断通讯录是否已满,如果满了就不再添加
if (abs->size == MAX) {
cout << "通讯录已满,无法添加!";
}
else {
// 添加联系人
cout << "\n请输入姓名:";
cin >> abs->perArry[abs->size].name;
cout << "\n请输入性别:" << "(注意1为男,0为女)";
int sex_nu = 0;
while (true) { // 如果输入有误,重新输入
cin >> sex_nu;
if (sex_nu == 0 || sex_nu == 1) {
abs->perArry[abs->size].sex = sex_nu;
break;
}
else {
cout << "输入错误,请重新输入!" << endl;
}
}
cout << "\n请输入年龄:";
cin >> abs->perArry[abs->size].age;
cout << "\n请输入电话:";
cin >> abs->perArry[abs->size].phone;
cout << "\n请输入地址:";
cin >> abs->perArry[abs->size].address;
abs->size ++;
cout << "\n添加成功" << endl;
system("pause");
}
}
// 显示联系人
void show(const AddressBooks* abs) { // 设置为只读
if (abs->size == 0) {
cout << "empty address books" << endl;
system("pause");
}
else{
for (int i = 0; i < abs->size; i++) { // 三目运算判断男女
cout << "姓名:" << abs->perArry[i].name << "\t性别:" << (abs->perArry[i].age == 1 ? "男" : "女")<< "\t年龄:" << abs->perArry[i].age << "\t电话:" << abs->perArry[i].phone << "\t地址:" << abs->perArry[i].address << endl;
}
system("pause");
}
}
// 判断用户是否存在,存在返回具体位置,不存在返回-1
int judge(AddressBooks* abs, string name) {
int index = -1; // 默认为-1
for (int i = 0; i < abs->size; i++) {
// 找到用户输入的姓名,返回i
if (abs->perArry[i].name == name) {
index = i;
}
}
return index;
}
// 删除联系人
void del(AddressBooks* abs, int index) {
for (int i = index; i < abs->size; i++) {
// 数据前移
abs->perArry[i] = abs->perArry[i + 1];
}
abs->size--; // 更新数据
cout << "删除成功" << endl;
system("pause");
}
// 查找联系人
void find(AddressBooks* abs, int index) {
cout << "姓名:" << abs->perArry[index].name << "\t性别:" << (abs->perArry[index].age == 1 ? "男" : "女") << "\t年龄:" << abs->perArry[index].age << "\t电话:" << abs->perArry[index].phone << "\t地址:" << abs->perArry[index].address << endl;
system("pause");
}
// 修改功能
void change(AddressBooks* abs, int index) {
// 添加联系人
cout << "\n请输入姓名:";
cin >> abs->perArry[index].name;
cout << "\n请输入性别:" << "(注意1为男,0为女)";
int sex_nu = 0;
while (true) { // 如果输入有误,重新输入
cin >> sex_nu;
if (sex_nu == 0 || sex_nu == 1) {
abs->perArry[index].sex = sex_nu;
break;
}
else {
cout << "输入错误,请重新输入!" << endl;
}
}
cout << "\n请输入年龄:";
cin >> abs->perArry[index].age;
cout << "\n请输入电话:";
cin >> abs->perArry[index].phone;
cout << "\n请输入地址:";
cin >> abs->perArry[index].address;
cout << "\n修改成功" << endl;
system("pause");
}
// 清空功能
void clear(AddressBooks* abs) {
abs->size = 0;
cout << "清空完成" << endl;
system("pause");
}
int main() {
int choice = 0;
// 创建通讯录结构体变量
AddressBooks abs;
// 通讯录中的初始化大小
abs.size = 0;
while (true) {
show_menu(); // 调用函数;显示菜单界面
cout << "请选择一个数字(0--6):";
cin >> choice;
// 选择功能
switch (choice) {
case 0: // 0、退出通讯录
cout << "欢迎下次使用!" << endl;
system("pause");
return 0; // 退出功能
case 1: // 1、添加联系人
addPerson(&abs);
system("cls"); // 清屏
break;
case 2: // 2、显示联系人
show(&abs);
system("cls"); // 清屏
break;
case 3: // 3、删除联系人
{ string name;
cout << "请输入要删除的联系人的姓名:";
cin >> name;
if (judge(&abs, name) == -1) {
cout << "没有该联系人!" << endl;
system("pause");
}
else {
del(&abs, judge(&abs, name));
}
system("cls");
break;
}
case 4: // 4、查找联系人
{ string name;
cout << "请输入要查找的联系人的姓名:";
cin >> name;
if (judge(&abs, name) == -1) {
cout << "没有该联系人!" << endl;
system("pause");
}
else {
find(&abs, judge(&abs, name));
}
system("cls");
break;
}
case 5: // 5、修改联系人
{ string name;
cout << "请输入要修改的联系人的姓名:";
cin >> name;
if (judge(&abs, name) == -1) {
cout << "没有该联系人!" << endl;
system("pause");
}
else {
change(&abs, judge(&abs, name));
}
system("cls");
break;
}
case 6: // 6、清空联系人
{cout << "您是否真的要清空全部联系人:(yes/no)" << endl;
while (true) {
string answer;
cin >> answer;
if (answer == "yes") {
clear(&abs);
system("cls");
break;
}
else if (answer == "no") {
cout << "正在取消操作" << endl;
system("cls");
break;
}
else {
cout << "请按照要求输入,输入yes / no";
}
}
break;
}
default:
cout << "input error" << endl;
system("pause");
system("cls"); // 清空界面
}
}
}
本文来自博客园,作者:Kenny_LZK,转载请注明原文链接:https://www.cnblogs.com/liuzhongkun/p/15806266.html