C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單通訊錄系統(tǒng)
更新時(shí)間:2021年07月28日 09:27:21 作者:編程乖乖
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單通訊錄系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本文實(shí)例為大家分享了C語(yǔ)言通訊錄系統(tǒng)(增刪改查),供大家參考,具體內(nèi)容如下
全部代碼如下所示:
#include <iostream>
#include <string>
using namespace std;
const int MAX = 1000;
//聯(lián)系人結(jié)構(gòu)體
typedef struct person
{
string m_name; //姓名
int m_sex; //性別 1 男,0 女
int m_age; //年齡
string m_phone; //電話
string m_addr; //住址
}person_t;
//通訊錄結(jié)構(gòu)體
typedef struct addressbooks
{
person_t personArray[MAX]; //通訊錄中保存的聯(lián)系人數(shù)組
int m_size; //通訊錄中人員個(gè)數(shù)
}addressbooks_t;
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;
}
void addPerson(addressbooks_t *abs)
{
//判斷通訊錄是否滿了,如果滿了就不再添加
if(abs->m_size == MAX)
{
cout << "通訊錄已滿,無(wú)法添加!" << endl;
return ;
}
else
{
//添加具體聯(lián)系人
cout << "請(qǐng)輸入姓名: ";
cin >> abs->personArray[abs->m_size].m_name;
int sex;
while(true)
{
cout << "請(qǐng)輸入性別(1男,0女): ";
cin >> sex;
if(sex == 1 || sex == 0)
{
abs->personArray[abs->m_size].m_sex = sex;
break;
}
else
{
cout << "輸入有誤,請(qǐng)重新輸入!" << endl;
}
}
cout << "請(qǐng)輸入年齡: ";
cin >> abs->personArray[abs->m_size].m_age;
cout << "請(qǐng)輸入電話: ";
cin >> abs->personArray[abs->m_size].m_phone;
cout << "請(qǐng)輸入地址: ";
cin >> abs->personArray[abs->m_size].m_addr;
//更新通訊錄人數(shù)
++ abs->m_size;
cout << "添加成功!" << endl;
system("pause");
}
}
void displayPerson(addressbooks_t *abs)
{
if(abs->m_size == 0)
{
cout << "記錄為空!" << endl;
}
else
{
cout << "姓名\t" << "年齡\t" << "性別\t" << "電話\t\t" << "地址\t\t" << endl;
for(int i = 0; i < abs->m_size; ++i)
{
cout << abs->personArray[i].m_name << "\t";
cout << abs->personArray[i].m_age << "\t";
cout << (abs->personArray[i].m_sex == 1 ? "男" : "女") << "\t";
cout << abs->personArray[i].m_phone << "\t";
cout << abs->personArray[i].m_addr << "\t";
cout << endl;
}
}
system("pause");
}
//按姓名查找用戶,如果查找到返回聯(lián)系人在數(shù)組中的下標(biāo),未查找到返回-1
int findByName(addressbooks_t *abs,string name)
{
for(int i = 0; i < abs->m_size; ++i)
{
if(name == abs->personArray[i].m_name)
{
return i;
}
}
return -1;
}
void deletePerson(addressbooks_t *abs)
{
string name;
cout << "請(qǐng)輸入要?jiǎng)h除聯(lián)的系人姓名:";
cin >> name;
int index = findByName(abs,name);
if(index == -1)
{
cout << "通訊錄中未查到" << name << endl;
}
else
{
for(int i = index; i < abs->m_size; ++i)
{
abs->personArray[i] = abs->personArray[i+1];
}
--abs->m_size;
cout << "刪除成功" << endl;
}
system("pause");
}
void findPerson(addressbooks_t *abs)
{
string name;
cout << "請(qǐng)輸入要查找的聯(lián)系人姓名:";
cin >> name;
int index = findByName(abs,name);
if(index == -1)
{
cout << "通訊錄中未查到" << name << endl;
}
else
{
cout << "姓名\t" << "年齡\t" << "性別\t" << "電話\t\t" << "地址\t\t" << endl;
cout << abs->personArray[index].m_name << "\t";
cout << abs->personArray[index].m_age << "\t";
cout << (abs->personArray[index].m_sex == 1 ? "男" : "女") << "\t";
cout << abs->personArray[index].m_phone << "\t";
cout << abs->personArray[index].m_addr << "\t";
cout << endl;
}
system("pause");
}
void updatePerson(addressbooks_t *abs)
{
string name;
cout << "請(qǐng)輸入要修改的聯(lián)系人姓名:";
cin >> name;
int index = findByName(abs,name);
if(index == -1)
{
cout << "通訊錄中未查到" << name << endl;
}
else
{
//添加具體聯(lián)系人
cout << "請(qǐng)輸入姓名: ";
cin >> abs->personArray[index].m_name;
int sex;
while(true)
{
cout << "請(qǐng)輸入性別(1男,0女): ";
cin >> sex;
if(sex == 1 || sex == 0)
{
abs->personArray[index].m_sex = sex;
break;
}
else
{
cout << "輸入有誤,請(qǐng)重新輸入!" << endl;
}
}
cout << "請(qǐng)輸入年齡: ";
cin >> abs->personArray[index].m_age;
cout << "請(qǐng)輸入電話: ";
cin >> abs->personArray[index].m_phone;
cout << "請(qǐng)輸入地址: ";
cin >> abs->personArray[index].m_addr;
cout << "修改成功!" << endl;
}
system("pause");
}
void clearPerson(addressbooks_t *abs)
{
abs->m_size = 0;
cout << "清空成功!" << endl;
system("pause");
}
int main()
{
//創(chuàng)建一個(gè)結(jié)構(gòu)體變量
addressbooks_t abs;
//初始化通訊錄中人員個(gè)數(shù)
abs.m_size = 0;
int select = 0; //創(chuàng)建用戶選擇輸入的變量
while(true)
{
system("cls"); //清空屏幕
showMenu(); //菜單調(diào)用
cout << "請(qǐng)輸入您的選擇: ";
cin >> select;
switch (select)
{
case 0: //0.退出通訊錄
cout << "歡迎下次使用" << endl;
return 0;
break;
case 1: //1.添加聯(lián)系人
addPerson(&abs);
break;
case 2: //2.顯示聯(lián)系人
displayPerson(&abs);
break;
case 3: //3.刪除聯(lián)系人
deletePerson(&abs);
break;
case 4: //4.查找聯(lián)系人
findPerson(&abs);
break;
case 5: //5.修改聯(lián)系人
updatePerson(&abs);
break;
case 6: //6.清空聯(lián)系人
clearPerson(&abs);
break;
default:
break;
}
}
return 0;
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++中使用mutable關(guān)鍵字的場(chǎng)景分析
C++中的mutable關(guān)鍵字用于修飾類的成員變量,使其在const成員函數(shù)中可以被修改,它主要用于緩存、線程同步和調(diào)試等場(chǎng)景,以支持對(duì)象的邏輯常量性,在使用mutable時(shí),應(yīng)確保其修改不會(huì)破壞對(duì)象的外部表現(xiàn)狀態(tài),本文介紹C++中使用mutable關(guān)鍵字的場(chǎng)景分析,感興趣的朋友一起看看吧2025-02-02
形參出現(xiàn)在函數(shù)定義中,在整個(gè)函數(shù)體內(nèi)都可以使用, 離開(kāi)該函數(shù)則不能使用。實(shí)參出現(xiàn)在主調(diào)函數(shù)中,進(jìn)入被調(diào)函數(shù)后,實(shí)參變量也不能使用,形參和實(shí)參的功能是作數(shù)據(jù)傳送。發(fā)生函數(shù)調(diào)用時(shí), 主調(diào)函數(shù)把實(shí)參的值傳送給被調(diào)函數(shù)的形參從而實(shí)現(xiàn)主調(diào)函數(shù)向被調(diào)函數(shù)的數(shù)據(jù)傳送2023-02-02
C++11中std::function與std::bind的用法實(shí)例
大家都知道C++11中增加了許多的新特性,下面這篇文章主要給大家介紹了關(guān)于C++11中std::function與std::bind的用法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05
C++通過(guò)boost.date_time進(jìn)行時(shí)間運(yùn)算
這篇文章介紹了C++通過(guò)boost.date_time進(jìn)行時(shí)間運(yùn)算的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06
C++多重繼承引發(fā)的重復(fù)調(diào)用問(wèn)題與解決方法
這篇文章主要介紹了C++多重繼承引發(fā)的重復(fù)調(diào)用問(wèn)題與解決方法,結(jié)合具體實(shí)例形式分析了C++多重調(diào)用中的重復(fù)調(diào)用問(wèn)題及相應(yīng)的解決方法,需要的朋友可以參考下2018-05-05
樹(shù)形結(jié)構(gòu)的3中搜索方式示例分享
樹(shù)的3中常見(jiàn)搜索方式,包括二叉樹(shù)方式(每一層只有0和1)、滿m叉樹(shù)(每一層都有0 到m - 1)、子集樹(shù),也稱為全排列樹(shù),需要的朋友可以參考下2014-02-02

