首页 > 编程语言 >【C++】通讯录管理系统+少量数据结构

【C++】通讯录管理系统+少量数据结构

时间:2024-07-11 23:30:47浏览次数:20  
标签:size cout C++ ret sex abs 通讯录 数据结构 name

#include <iostream>
#include <string>
using namespace std;

#define max 1000

struct newp {
	string name;
	int sex ;
	int age ;
	string number;
	string add;
};

struct books {
	struct newp a[max];
	int size ;
};

static 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 add(books * abs) {
	if (abs->size == max) {
	
		cout << "通讯录存储空间已满,数据逸出" << endl;
		return;

	}
	else 
	{
		string name;
		cout << "输入姓名:" << endl;
		cin >> name;
		abs->a[abs->size].name = name;
		
		cout << "输入性别:\t 1 -- 男 \t 2 -- 女" << endl;
		int sex = 0;
		while (true) {
			cin >> sex;
			if (sex == 1 || sex == 2) 
			{

				abs->a[abs->size].sex = sex;
				break;

			}
			cout << "输入有误,请重新输入" << endl;
		}

		cout << "输入年龄:" << endl;
		int age = 0;
		while (true) {
			cin >> age;
			if (age > 0 && age <= 150) {

				abs->a[abs->size].age = age;
				break;

			}
			cout << "输入有误,请重新输入" << endl;
		}

		string number;
		cout << "输入手机号:" << endl;
		cin >> number;
		abs->a[abs->size].number = number;

		string add;
		cout << "输入地址:" << endl;
		cin >> add;
		abs->a[abs->size].add = add;

		//更新通讯录
		abs->size++;

		cout << "** 完成存储 **" << endl;
	
		system("pause");
		system("cls");//清屏
	}

}

static void show(books * abs) {

	if (abs->size == 0) {
		
		cout << "当前通讯录为空" << endl;

	}
	else
	{
		for (int i = 0; i < abs->size; i++) {

			cout << "姓名:" << abs->a[i].name << "\t";
			cout << "性别:" << (abs->a[i].sex == 1 ? "男":"女") << "\t";
			cout << "输入年龄:" << abs->a[i].age << "\t";
			cout << "手机号:" << abs->a[i].number << "\t";
			cout << "输入地址:" << abs->a[i].add << endl;

		}
	}
	system("pause");
	system("cls");
}

static int isExist(books * abs, string name) {

	for (int i = 0; i < abs->size; i++) {
	
		if (abs->a[i].name == name)
		{
			return i;
		}
	}
	return -1;

}

static void del(books * abs) {

	string name;
	cout << "请输入要删除的用户姓名" << endl;
	cin >> name;

	int ret = isExist(abs, name);
	if ( ret != -1) {

		for (int i = ret; i < abs->size; i++)
		{
			//数据前移
			abs->a[i] = abs->a[i + 1];
		}
		//更新通讯录人数
		abs->size--;
		cout << "** 删除成功 **" << endl;
	}
	else
	{
		cout << "该用户不存在" << endl;
	}
	
	system("pause");
	system("cls");
	
}

static void search(books * abs){

	string name;
	cout << "请输入要查找的用户姓名" << endl;
	cin >> name;

	int ret = isExist(abs, name);
	if ( ret != -1) {

		cout << "姓名:" << abs->a[ret].name << "\t";
		cout << "性别:" << (abs->a[ret].sex == 1 ? "男" : "女") << "\t";
		cout << "输入年龄:" << abs->a[ret].age << "\t";
		cout << "手机号:" << abs->a[ret].number << "\t";
		cout << "输入地址:" << abs->a[ret].add << endl;
	
	}
	else 
	{
		cout << "不存在该联系人" << endl;
	}

	system("pause");
	system("cls");
}

static void remark(books* abs) {

	string name;
	cout << "请输入要修改的用户姓名" << endl;
	cin >> name;

	int ret = isExist(abs, name);
	if (ret != -1) {

		string na;
		cout << "输入姓名:" << endl;
		cin >> na;
		abs->a[ret].name = name;

		cout << "输入性别:\t 1 -- 男 \t 2 -- 女" << endl;
		int sex = 0;
		while (true) {
			cin >> sex;
			if (sex == 1 || sex == 2)
			{
				abs->a[ret].sex = sex;
				break;
			}
			cout << "输入有误,请重新输入" << endl;
		}

		cout << "输入年龄:" << endl;
		int age = 0;
		while (true) {
			cin >> age;
			if (age > 0 && age <= 150) {

				abs->a[ret].age = age;
				break;

			}
			cout << "输入有误,请重新输入" << endl;
		}

		string number;
		cout << "输入手机号:" << endl;
		cin >> number;
		abs->a[ret].number = number;

		string add;
		cout << "输入地址:" << endl;
		cin >> add;
		abs->a[ret].add = add;

		cout << "** 完成修改 **" << endl;

	}
	else
	{
		cout << "该用户不存在" << endl;
	}

	system("pause");
	system("cls");//清屏

}

static void clean(books * abs) {

	abs->size = 0;
	cout << "通信录已清空" << endl;
	system("pause");
	system("cls");

}

int main() {
	
	books abs;
	//初始化当前人员个数
	abs.size = 0;

	int k = 0;
	
	while (true) { //true
	
		showMenu();
		
		cin >> k;

		switch (k) {
		case 1:add(&abs); break;//利用地址传递可以修改值
		case 2:show(&abs); break;
		case 3:del(&abs); break;
		case 4:search(&abs); break;
		case 5:remark(&abs); break;
		case 6:clean(&abs); break;
		case 0:cout << "** 退出程序 **" << endl;
			   system("pause");
			   return 0;
			   break;
		default:cout << "请检查输入是否有误" << endl; break;
		}

	}

	system("pause");
	return 0;
}

标签:size,cout,C++,ret,sex,abs,通讯录,数据结构,name
From: https://blog.csdn.net/weixin_60546365/article/details/140364531

相关文章

  • 【C++ 】C++ 停车场收费系统(源码)【独一无二】
    ......
  • C++入门——“命名空间”、“缺省参数”、“函数重载”、“引用”
    C++在C语言的基础上增加了许多东西,在我看来,它和它的名字一样,是C语言的Plus的Plus版本,而且支持C语言的大部分语法,让码农写起来很是别有一番韵味。在这里向大家介绍C++的一些语法结构。一、命名空间    在进行C语言的开发当中,随着代码量的增加,或者工程变得复杂,我们进行......
  • C++——类和对象(上)
    文章目录一、类的定义1.类定义格式2.访问限定符3.类域二、实例化1.实例化概念2.对象⼤⼩三、this指针一、类的定义1.类定义格式与定义结构体类似classST{ //成员变量 intval; //成员函数 voidprint() { cout<<val<<endl; }};class为定义类......
  • C++ 入门07:静态成员和常量成员
    往期回顾:C++入门04:数组与字符串-CSDN博客C++入门05:类和对象-CSDN博客C++入门06:类的进阶(构造函数的重载与拷贝构造函数)-CSDN博客 一、前言在前面文章的学习中,我们掌握了类和对象的基础知识以及构造函数的重载与拷贝构造函数。今天,我们将学习类的静态成员和常量成员......
  • 数据结构复习计划之复杂度分析(时间、空间)
    第二节:算法时间复杂度和空间复杂度算法(Algorithm):是对特定问题求解方法(步骤)的一种描述,是指令的有限序列,其中每一条指令表示一个或多个操作。算法可以有三种表示形式: 伪代码 自然语言 流程图算法的五个特性①有穷性:一个算法必须总是在执行有穷步......
  • C++算法实践07-回文数
    一、题目:给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。例如,121 是回文,而 123 不是。示例1:输入:x=121输出:true示例 2:输入:x=-121输出:false解释:从左向右读,为-121。从右......
  • C++算法实践06-整数反转
    一、题目:给你一个32位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。如果反转后整数超过32位的有符号整数的范围 [−231, 231 −1] ,就返回0。假设环境不允许存储64位整数(有符号或无符号)。示例1:输入:x=123输出:321示例2:输入:x=-123输出:-321示例......
  • 【数据结构】双向链表
    Hi~!这里是奋斗的小羊,很荣幸您能阅读我的文章,诚请评论指点,欢迎欢迎~~......
  • C++冒泡排序(使用vector动态数组)
    #include<iostream>#include<vector>usingnamespacestd;voidsort(vector<int>&a){  constintsize=a.size();  inttemp;  intflag=1;  while(flag==1)  {  flag=0;  for(inti=0;i<size;++i)  {   if(a[i]>......
  • c++方法
    std::transform方法std::transform是C++标准库算法中的一个非常有用的函数,它定义在头文件中。这个函数用于将给定范围内的每个元素按照指定的操作进行转换,并将转换结果存储在另一个位置(可以是原始范围的另一个容器,或者完全不同的位置)。std::transform提供了一个灵活的......