亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++實(shí)現(xiàn)簡(jiǎn)易通訊錄

 更新時(shí)間:2020年07月23日 10:40:35   作者:逆風(fēng)行礫  
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡(jiǎn)易通訊錄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了C++實(shí)現(xiàn)簡(jiǎn)易通訊錄的具體代碼,供大家參考,具體內(nèi)容如下

#include <iostream>
#include <string>
#define MAX 1000
using namespace std;

// 設(shè)計(jì)聯(lián)系人的結(jié)構(gòu)體
struct Person 
{
 string m_Name;
 int m_Sex;  // 1、男  2 女
 int m_Age;
 string m_Phone;
 string m_Addr;
};

// 設(shè)計(jì)通訊錄的結(jié)構(gòu)體
struct Addressbooks
{
 struct Person personArray[MAX];
 int m_Size;
};


// 1、菜單界面
void showMenu()
{
 cout << "***************************" << endl;
 cout << "***** 1、添加聯(lián)系人 *****" << endl;
 cout << "***** 2、顯示聯(lián)系人 *****" << endl;
 cout << "***** 3、刪除聯(lián)系人 *****" << endl;
 cout << "***** 4、查找聯(lián)系人 *****" << endl;
 cout << "***** 5、修改聯(lián)系人 *****" << endl;
 cout << "***** 6、清空聯(lián)系人 *****" << endl;
 cout << "***** 0、退出通訊錄 *****" << endl;
 cout << "***************************" << endl;
}
// 2、添加聯(lián)系人
void addPerson(Addressbooks * abs)
{
 // 判斷通訊錄是否已滿(mǎn)
 if (abs->m_Size == MAX)
 {
 cout << "通訊錄已經(jīng)滿(mǎn),無(wú)法添加!" << endl;
 return;
 }
 else
 {
 // 添加具體聯(lián)系人
 string name;
 cout << "請(qǐng)輸入姓名:" << endl;
 cin >> name;
 abs->personArray[abs->m_Size].m_Name = name;
 cout << "請(qǐng)輸入性別:" << endl;
 cout << "1----男\(zhòng)n2----女" << endl;
 int sex = 0;
 while (true)
 {
  cin >> sex;
  if (sex == 1 || sex == 2)
  {
  abs->personArray[abs->m_Size].m_Sex = sex;
  break;
  }
  cout << "輸入有誤,請(qǐng)重新輸入" << endl;
 }
 cout << "請(qǐng)輸入年齡:" << endl;
 int age = 0;
 cin >> age;
 abs->personArray[abs->m_Size].m_Age = age;

 cout << "請(qǐng)輸入聯(lián)系電話(huà):" << endl;
 string phone;
 cin >> phone;
 abs->personArray[abs->m_Size].m_Phone = phone;

 cout << "請(qǐng)輸入家庭地址:" << endl;
 string address;
 cin >> address;
 abs->personArray[abs->m_Size].m_Addr = address;
 abs->m_Size++;
 
 cout << "添加成功!" << endl;

 system("pause"); // 請(qǐng)按任意鍵繼續(xù)
 system("cls");  // 清屏操作
 }

}

// 3、顯示所有的聯(lián)系人
void showPerson(Addressbooks * abs)
{
 // 判斷通訊錄中人數(shù)是否為0
 if (abs->m_Size == 0)
 {
 cout << "當(dāng)前記錄為空" << endl;
 }
 else
 {
 for (int i = 0; i < abs->m_Size; i++)
 {
  cout << "姓名:" << abs->personArray[i].m_Name << "\t";
  cout << "性別:" << (abs->personArray[i].m_Sex == 1 ? "男" : "女") << "\t";
  cout << "年齡:" << abs->personArray[i].m_Age << "\t";
  cout << "電話(huà):" << abs->personArray[i].m_Phone << "\t";
  cout << "住址:" << abs->personArray[i].m_Addr << endl;
 }
 }
 system("pause");
 system("cls");
}

// 4、檢測(cè)聯(lián)系人是否存在,若存在,返回聯(lián)系人所在數(shù)組中的具體位置 
// 參數(shù)1 通訊錄  參數(shù)2 對(duì)比姓名
int isExit(Addressbooks * abs, string name)
{
 for (int i = 0; i < abs->m_Size; i++)
 {
 if (abs->personArray[i].m_Name == name)
 {
  return i;  //找到了,返回該人在數(shù)組中的編號(hào)
 }
 }
 return -1;     // 沒(méi)有找到,則返回-1
} 

// 5、刪除指定的聯(lián)系人
void deletePerson(Addressbooks * abs)
{
 cout << "請(qǐng)輸入您要?jiǎng)h除的聯(lián)系人姓名:" << endl;
 string name;
 cin >> name;
 int ret = isExit(abs, name);
 if (ret != -1)
 {
 // 找到此人 進(jìn)行刪除操作
 for (int i = ret; i < abs->m_Size; i++)
 {
  abs->personArray[i] = abs->personArray[i + 1];
 }
 abs->m_Size--;
 cout << "刪除成功" << endl;
 }
 else
 {
 cout << "查無(wú)此人" << endl;
 }
 system("pause");
 system("cls");
}

// 6、查找指定的聯(lián)系人信息
void findPerson(Addressbooks * abs)
{
 cout << "請(qǐng)輸入您要查找的聯(lián)系人:" << endl;
 string name;
 cin >> name;
 int ret = isExit(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 << "電話(huà):" << abs->personArray[ret].m_Phone << "\t";
 cout << "地址:" << abs->personArray[ret].m_Addr << endl;;
 }
 else
 {
 cout << "查無(wú)此人" << endl;
 }
 system("pause");
 system("cls");
}

// 7、修改指定的聯(lián)系人信息
void modifyPerson(Addressbooks * abs)
{
 cout << "請(qǐng)輸入您要修改的聯(lián)系人:" << endl;
 string name;
 cin >> name;
 int ret = isExit(abs, name);
 if (ret != -1)
 {
 string name;
 cout << "請(qǐng)輸入姓名:" << endl;
 cin >> name;
 abs->personArray[ret].m_Name = name;
 cout << "請(qǐng)輸入性別:" << endl;
 cout << "1---男\(zhòng)t2---女" << endl;
 int sex = 0;
 //cin >> sex;
 while (true)
 {
  cin >> sex;
  if (sex == 1 || sex == 2)
  {
  abs->personArray[ret].m_Sex = sex;
  break;
  }
  cout << "輸入錯(cuò)誤,請(qǐng)重新輸入:" << endl;
 }
 cout << "請(qǐng)輸入年齡:" << endl;
 int age = 0;
 cin >> age;
 abs->personArray[ret].m_Age = age;
 cout << "請(qǐng)輸入聯(lián)系電話(huà):" << endl;
 string phone;
 cin >> phone;
 abs->personArray[ret].m_Phone = phone;
 cout << "請(qǐng)輸入一個(gè)家庭地址:" << endl;
 string address;
 cin >> address;
 abs->personArray[ret].m_Addr = address;
 }
 else
 {
 cout << "查無(wú)此人" << endl;
 }
 system("pause");
 system("cls");
}

// 8、清空聯(lián)系人
void cleanPerson(Addressbooks * abs)
{
 abs->m_Size = 0;
 cout << "聯(lián)系人已經(jīng)清空?。?!" << endl;
 system("pause");
 system("cls");
}


int main()
{
 // 創(chuàng)建通訊錄結(jié)構(gòu)體變量
 Addressbooks abs;
 // 初始化通訊錄中當(dāng)前人數(shù)為0
 abs.m_Size = 0;


 int select = 0;  

 while (true)
 {
 // 菜單調(diào)用
 showMenu();

 cin >> select;
 switch (select)
 {
 case 1: // 1、添加聯(lián)系人
  addPerson(&abs); //利用地址傳遞可以修飾實(shí)參
  break;
 case 2: // 2、顯示聯(lián)系人
  showPerson(&abs);
  break;
 case 3: // 3、刪除聯(lián)系人
  deletePerson(&abs);
 /* {
  cout << "請(qǐng)輸入刪除聯(lián)系人的姓名:" << endl;
  string name;
  cin >> name;
  if (isExit(&abs, name) == -1)
  {
  cout << "查無(wú)此人" << endl;
  }
  else
  {
  cout << "找到此人" << endl;
  }
 }*/
  break;
 case 4: // 4、查找聯(lián)系人
  findPerson(&abs);
  break;
 case 5: // 5、修改聯(lián)系人
  modifyPerson(&abs);
  break;
 case 6: // 6、清空聯(lián)系人
  cleanPerson(&abs);
  break;
 case 0: // 0、退出通訊錄
  cout << "歡迎下次使用" << endl;
  system("pause");
  return 0;
  break;
 default:
  break;
 }

 }

 
 system("pause");
 return 0;
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • VC++?2019?"const?char*"類(lèi)型的實(shí)參與"LPCTSTR"類(lèi)型的形參不兼容解決

    VC++?2019?"const?char*"類(lèi)型的實(shí)參與"LPCTSTR"

    這篇文章主要給大家介紹了關(guān)于VC++?2019?"const?char*"類(lèi)型的實(shí)參與"LPCTSTR"類(lèi)型的形參不兼容的解決方法,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-03-03
  • C++ Boost Heap使用實(shí)例詳解

    C++ Boost Heap使用實(shí)例詳解

    Boost是為C++語(yǔ)言標(biāo)準(zhǔn)庫(kù)提供擴(kuò)展的一些C++程序庫(kù)的總稱(chēng)。Boost庫(kù)是一個(gè)可移植、提供源代碼的C++庫(kù),作為標(biāo)準(zhǔn)庫(kù)的后備,是C++標(biāo)準(zhǔn)化進(jìn)程的開(kāi)發(fā)引擎之一,是為C++語(yǔ)言標(biāo)準(zhǔn)庫(kù)提供擴(kuò)展的一些C++程序庫(kù)的總稱(chēng)
    2022-11-11
  • 詳細(xì)理解函C語(yǔ)言的函數(shù)棧幀

    詳細(xì)理解函C語(yǔ)言的函數(shù)棧幀

    這篇文章主要為大家介紹了C語(yǔ)言的函數(shù)棧幀,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助,希望能夠給你帶來(lái)幫助
    2021-11-11
  • C語(yǔ)言實(shí)現(xiàn)飛機(jī)售票系統(tǒng)

    C語(yǔ)言實(shí)現(xiàn)飛機(jī)售票系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)飛機(jī)售票系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • 深入解讀C++ 內(nèi)聯(lián)函數(shù)inline|nullptr

    深入解讀C++ 內(nèi)聯(lián)函數(shù)inline|nullptr

    內(nèi)聯(lián)函數(shù):用** inline 修飾的函數(shù)叫做內(nèi)聯(lián)函數(shù),編譯時(shí)C++編譯器會(huì)在調(diào)用的地方展開(kāi)內(nèi)聯(lián)函數(shù)**,這樣調(diào)用內(nèi)聯(lián)函數(shù)就需要?jiǎng)?chuàng)建棧楨,就提高效率了,這篇文章給大家介紹C++ 內(nèi)聯(lián)函數(shù)inline|nullptr的相關(guān)知識(shí),感興趣的朋友跟隨小編一起看看吧
    2024-07-07
  • C語(yǔ)言求階乘之和的三種實(shí)現(xiàn)方法(先階乘再累加)

    C語(yǔ)言求階乘之和的三種實(shí)現(xiàn)方法(先階乘再累加)

    對(duì)于C/C++初學(xué)者來(lái)說(shuō),可能會(huì)經(jīng)常遇到如計(jì)算階乘等問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言求階乘之和的三種實(shí)現(xiàn)方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • C++鏈表類(lèi)的封裝詳情介紹

    C++鏈表類(lèi)的封裝詳情介紹

    這篇文章主要介紹了C++鏈表類(lèi)的封裝,文章基于C++的相關(guān)資料展開(kāi)主題的詳細(xì)內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-04-04
  • C++ Eigen庫(kù)實(shí)現(xiàn)最小二乘擬合的示例代碼

    C++ Eigen庫(kù)實(shí)現(xiàn)最小二乘擬合的示例代碼

    Eigen 是一個(gè)線(xiàn)性算術(shù)的 C++ 模板庫(kù),功能強(qiáng)大、快速、優(yōu)雅以及支持多平臺(tái),本文主要為大家介紹了C++利用Eigen庫(kù)實(shí)現(xiàn)最小二乘擬合的示例代碼,希望對(duì)大家有所幫助
    2023-07-07
  • C++中產(chǎn)生臨時(shí)對(duì)象的情況及其解決方案

    C++中產(chǎn)生臨時(shí)對(duì)象的情況及其解決方案

    這篇文章主要介紹了C++中產(chǎn)生臨時(shí)對(duì)象的情況及其解決方案,以值傳遞的方式給函數(shù)傳參,類(lèi)型轉(zhuǎn)換以及函數(shù)需要返回對(duì)象時(shí),并給對(duì)應(yīng)給出了詳細(xì)的解決方案,通過(guò)圖文結(jié)合的方式講解的非常詳細(xì),需要的朋友可以參考下
    2024-05-05
  • C++ stack與queue模擬實(shí)現(xiàn)詳解

    C++ stack與queue模擬實(shí)現(xiàn)詳解

    這篇文章主要給大家介紹了關(guān)于c++stack與queue模擬實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-08-08

最新評(píng)論