首页 > 其他分享 >2023.4.17

2023.4.17

时间:2023-04-17 20:36:24浏览次数:38  
标签:cout 17 int ret Sex abs 2023.4 personArray

#include<iostream>
#include<string>
#define MAX 1000
using namespace std;
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;
}
struct Person {
string m_Name;
int m_Sex;
int m_Age;
string m_Phone;
string m_Addr;
};
struct Addressbooks {
struct Person personArray[MAX];
int m_Size;
};
void addPerson(Addressbooks* abs) {
if (abs->m_Size == MAX)
{
cout << "通讯录已满,无法添加!" << endl;
return;
}
else
{
string name;
cout << "请输入姓名:" << endl;
cin >> name;
abs->personArray[abs->m_Size].m_Name = name;
int m_Sex=0;
cout << "请输入性别:" << endl;
cout << "1---男" << endl;
cout << "2---女" << endl;
while(true){
cin >> m_Sex;
if (m_Sex == 1 || m_Sex == 2)
{
abs->personArray[abs->m_Size].m_Sex = m_Sex;
break;
}
cout << "输入有误,请重新输入" << endl;
}
int m_Age=0;
cout << "请输入年龄" << endl;
cin >> m_Age;
abs->personArray[abs->m_Size].m_Age = m_Age;
string m_Phone;
cout << "请输入联系电话" << endl;
cin >> m_Phone;
abs->personArray[abs->m_Size].m_Phone = m_Phone;
string m_Addr;
cout << "请输入家庭住址" << endl;
cin >> m_Addr;
abs->personArray[abs->m_Size].m_Addr = m_Addr;
abs->m_Size++;
cout << "添加成功" << endl;
system("pause");
system("cls");
}
}
void showPerson(Addressbooks* abs) {
if (abs->m_Size == 0) {
cout << "当前记录为空" << endl;
}
else {
for (int i = 0; i < abs->m_Size; i++) {
cout << "姓名:" << abs->personArray[i].m_Name << "\t";
if (abs->personArray[i].m_Sex == 1) {
cout << "性别:男" << "\t";
}
else if (abs->personArray[i].m_Sex == 2) {
cout << "性别:女" << "\t";
}
cout << "年龄:" << abs->personArray[i].m_Age << "\t";
cout << "联系电话:" << abs->personArray[i].m_Phone << "\t";
cout << "家庭住址:" << abs->personArray[i].m_Addr << endl;

}
}
system("pause");
system("cls");
}
int isExist(Addressbooks* abs,string m_Name) {
for (int i = 0; i < abs->m_Size; i++)
{
if (abs->personArray[i].m_Name == m_Name)
{
return i;
}
}
return -1;
}
void deletePerson(Addressbooks* abs) {
cout << "请输入要删除的联系人" << endl;
string name;
cin >> name;
int ret = isExist(abs, name);
if (ret != -1) {
for (int i = ret; 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 findPerson(Addressbooks* abs) {
cout << "请输入您要查找的联系人" << endl;
string name;
cin >> name;
int ret = isExist(abs, name);
if (ret != -1) {
cout << "姓名:" << abs->personArray[ret].m_Name << "\t";
cout << "性别:" << abs->personArray[ret].m_Sex << "\t";
cout << "年龄:" << abs->personArray[ret].m_Age << "\t";
cout << "电话:" << abs->personArray[ret].m_Phone<< "\t";
cout << "家庭住址:" << abs->personArray[ret].m_Addr << endl;
}
else {
cout << "未找到联系人" << endl;
}
system("pause");
system("cls");
}
void modifyPerson(Addressbooks* abs) {
cout << "请输入您要修改的联系人姓名" << endl;
string name;
cin >> name;
int ret = isExist(abs, name);
if (ret != -1) {
string Name;
cout << "请输入新的联系人姓名" << endl;
cin >> Name;
abs->personArray[ret].m_Name = Name;
int Sex;
cout << "请输入新的联系人性别" << endl;
cout << "1---男" << endl;
cout << "2---女" << endl;
while(true){
cin >> Sex;
if (Sex == 1 || Sex == 2) {
abs->personArray[ret].m_Sex = Sex;
break;
}
else {
cout << "请重新输入有效值" << endl;
}
}
int Age;
cout << "请输入新的联系人年龄" << endl;
cin >> Age;
abs->personArray[ret].m_Age = Age;
string Phone;
cout << "请输入新的联系人电话" << endl;
cin >> Phone;
abs->personArray[ret].m_Phone = Phone;
string Address;
cout << "请输入新的联系人地址" << endl;
cin >> Address;
abs->personArray[ret].m_Addr = Address;
cout << "修改成功" << endl;
}
else {
cout << "查无此人" << endl;
}
system("pause");
system("cls");
}
void deleteallPerson(Addressbooks* abs) {
abs->m_Size = 0;
cout << "通讯录已清空" << endl;
system("pause");
system("cls");
}
int main() {
struct Addressbooks abs;
abs.m_Size = 0;
int select = 0;
while (true) {
showMenu();
cin >> select;
switch (select)
{
case 1:
addPerson(&abs);
break;
case 2:
showPerson(&abs);
break;
case 3:
deletePerson(&abs);
break;
case 4:
findPerson(&abs);
break;
case 5:
modifyPerson(&abs);
break;
case 6:
deleteallPerson(&abs);
break;
case 0:
cout << "欢迎下次使用" << endl;
system("pause");
return 0;
break;
default:
break;
}
}

system("pause");
return 0;
}

标签:cout,17,int,ret,Sex,abs,2023.4,personArray
From: https://www.cnblogs.com/lml66/p/17327381.html

相关文章

  • The Super Powers UVA - 11752
     求1~2^64区间里,有多少合法数X合法数:X=a^b,至少存在2个不同的a #include<iostream>#include<algorithm>#include<vector>usingnamespacestd;constintN=65536+3;intb[int(1e6)];__int128_tMAX=1;voidinit(){ inti,j; b[0]=b[1]=1; fo......
  • 编程一小时2023.4.17
    1.#include<bits/stdc++.h>usingnamespacestd;typedeflonglongll;classVehicle{protected:stringNO;public:Vehicle(stringstr){NO=str;}virtualvoiddisplay()=0;virtual~Vehicle(){};};classCar:publicVehicle{int......
  • 4.17总结
    分工:需要负责前端页面的实现和用户体验的优化,保证系统界面美观、易用性高。以及团队工作的调动协调。  ......
  • 贪心_20230417
    452.用最少数量的箭引爆气球题目说明有一些球形气球贴在一堵用XY平面表示的墙面上。墙面上的气球记录在整数数组points,其中points[i]=[xstart,xend]表示水平直径在xstart和xend之间的气球。你不知道气球的确切y坐标。一支弓箭可以沿着x轴从不同点完全垂直地......
  • 每日打卡4.17
    一、问题描述:中国有句俗语叫“三天打鱼两天晒网”。某人从1990年1月1日起开始“三天打鱼两天晒网”,问这个人在以后的某一天中是“打鱼”还是“晒网”。二、设计思路:根据题意可以将解题过程分为3步(1)计算从1990年1月1日开始至指定日期共有多少天。(2)由于“打鱼”和“晒网”的周......
  • 2023.4.17 那是谁 在放古老唱片
    加训大数据结构。「LG6109」[Ynoi2009]rprmq1在一般的矩形修改问题中,有时间,横坐标,纵坐标三维,而这题只有横纵坐标两维,所以这本质上是序列上的问题。如果对于每次查询,都有\(l_1=1\),那么直接扫描线,用线段树维护第二维的历史最大值就好了。对于一般情况,需要在第一维进行分治,用类......
  • 4月17日每日总结
    负责领导团队完成项目,并且担任整个系统的开发负责人。需要具备全栈工程师的技能,了解并掌握前后端技术,包括但不限于数据库设计、API接口设计、服务器搭建、Web开发等方面的知识 ......
  • 跨屏零代码saas建站平台2023.4.17发布更新
    跨屏零代码saas建站平台2023.4.17发布更新,对于用户管理后台中的菜单设置做了升级,允许新增菜单并且自定义菜单链接,这样可以让网站菜单变得更加灵活可控,可以满足不同模板中多样的需求,升级以后的网站菜单支持添加菜单,删除菜单,控制菜单是否在导航显示,设置菜单排序,修改菜单名称等。......
  • 2023/4/17 SCRUM个人博客
    1、我昨天的成就:昨天进行了程序的ui设计方面,将之前不太合理的地方进行了更新修改,用了三小时的时间,还剩余十小时2、遇到了什么困难困难主要就在于代码之间的牵扯关系很深,改了这里,其他地方也要修改,但是好在最后改完了。3、今天的任务今天的任务主要是将视频画面绘......
  • 202304177_京良路西延近况2
    京良路西延最新拆迁情况2京良路西段工程一直备受房山居民关注那么,京良路西段现在建的咋样了?变化比较大的就是京良路收费站出来后的这个高架桥目前桥基的填埋物已经基本填平预计后期将会进行压路铺油高架桥西侧的断点目前没再往前延伸不过下方有施工人员像是在拆除施工围......