利用C語言結(jié)構(gòu)體實現(xiàn)通訊錄
更新時間:2019年01月31日 14:08:51 作者:MyFamily_IT
這篇文章主要為大家詳細介紹了利用C語言結(jié)構(gòu)體實現(xiàn)通訊錄,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了C語言結(jié)構(gòu)體實現(xiàn)通訊錄的具體代碼,供大家參考,具體內(nèi)容如下
用來存儲1000個人的信息的通訊錄,每個人的信息包括:
姓名、性別、年齡、電話、住址
程序如下:
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
struct People
{
char name[20];
char sex[5];
int age;
char tel[15];
char addr[50];
}; //定義人的信息結(jié)構(gòu)體(包含各種信息)
struct Contact
{
struct People person[1000]; //定義通訊錄結(jié)構(gòu)體
int n; //(包含人的信息的結(jié)構(gòu)體和用戶個數(shù)n)
};
typedef struct Contact * p;
void menu();
int add(p q); //p是一個結(jié)構(gòu)體指針類型,q是一個指向struct Contact的一個指針
int delete(p q); //例如:typedef int * int 即 int *p ==> int p
int find(p q);
int modify(p q);
int show(p q);
int clear(p q); //函數(shù)的聲明
void menu() //目錄格式
{
printf("====================歡迎來到蘇嵌154通訊錄==================\n");
printf("----------------------1.添加聯(lián)系人信息---------------------\n");
printf("----------------------2.刪除指定聯(lián)系人信息-----------------\n");
printf("----------------------3.查找指定聯(lián)系人信息-----------------\n");
printf("----------------------4.修改指定聯(lián)系人信息-----------------\n");
printf("----------------------5.顯示所有聯(lián)系人信息-----------------\n");
printf("----------------------6.清空所有聯(lián)系人---------------------\n");
printf("----------------------0.謝謝使用---------------------------\n");
printf("====================歡迎來到蘇嵌154通訊錄==================\n");
}
int add(p q) //添加聯(lián)系人
{
if((*q).n >= 1000)
{
printf("contact is full!\n");
return -1;
}
else
{
printf("輸入姓名:\n");
scanf("%s",(*q).person[(*q).n].name);
printf("輸入性別:\n");
scanf("%s",(*q).person[(*q).n].sex);
printf("輸入年齡:\n");
scanf("%d",&(*q).person[(*q).n].age);
printf("輸入電話:\n");
scanf("%s",(*q).person[(*q).n].tel);
printf("輸入地址:\n");
scanf("%s",(*q).person[(*q).n].addr);
((*q).n)++;
}
return 0;
}
int delete(p q) //刪除聯(lián)系人
{
int ret = find(q); //調(diào)用查找函數(shù)并保存其值
if(ret != -1)
{
int i = 0;
i = ret; //這里要用另一個變量來保存輸入的姓名
for(i = 0;i < (*q).n-1;i++)
{
(*q).person[i] = (*q).person[i+1]; //用后一個覆蓋前邊的,如果要刪除的是最后一個不進行此步驟
}
(*q).n --; //直接減去最后一個即count--
}
return 0;
}
int find(p q) //查找聯(lián)系人
{
int i = 0;
char ret[20]; //用另一個數(shù)組來保存姓名
printf("輸入姓名:\n");
scanf("%s",ret);
while(i <= (*q).n)
{
if(strcmp(ret,(*q).person[i].name)== 0) //比較輸入的姓名和通訊錄中已有的姓名
{
printf("姓名\t性別\t年齡\t電話\t地址\4t\n"); //制表符來制作表頭
printf("%s\t",(*q).person[i].name);
printf("%s\t",(*q).person[i].sex);
printf("%d\t",(*q).person[i].age);
printf("%s\t",(*q).person[i].tel);
printf("%s\4t\n",(*q).person[i].addr);
return i;
}
i++;
}
printf("你丫的我班沒這個人\n");
return -1;
}
int modify(p q) //修改函數(shù),首先找到如要修改的姓名,然后重新輸入
{
int ret = find(q);
if(ret != -1)
{
printf("輸入修改的姓名:\n");
scanf("%s",(*q).person[ret].name);
printf("輸入修改的性別:\n");
scanf("%s",(*q).person[ret].sex);
printf("輸入修改的年齡:\n");
scanf("%d",&((*q).person[ret].age));
printf("輸入修改的電話:\n");
scanf("%s",(*q).person[ret].tel);
printf("輸入修改的地址:\n");
scanf("%s",(*q).person[ret].addr);
}
else
{
printf("你丫的我班沒這個人\n");
}
return 0;
}
int show(p q) //顯示全部聯(lián)系人
{
int i = 0;
printf("姓名\t性別\t年齡\t電話\t地址\4t\n");
for(i = 0;i < (*q).n;i++)
{
printf("%s\t",(*q).person[i].name);
printf("%s\t",(*q).person[i].sex);
printf("%d\t",(*q).person[i].age);
printf("%s\t",(*q).person[i].tel);
printf("%s\4t\n",(*q).person[i].addr);
}
printf("\n");
return 0;
}
int clear(p q) //清除所有人,直接讓成員個數(shù)變?yōu)?
{
(*q).n = 0 ;
return 0;
}
int main()
{
int n=1;
struct Contact people; //調(diào)用通訊錄結(jié)構(gòu)體
people.n = 0; //初始化n
while(n)
{
menu();
printf("請選擇你的騷操作:\n");
scanf("%d",&n);
switch(n) //switch case語句分支選擇不同函數(shù)實現(xiàn)不同作用
{
case 1:
{
add(&people);
break;
}
case 2:
{
delete(&people);
break;
}
case 3:
{
find(&people);
break;
}
case 4:
{
modify(&people);
break;
}
case 5:
{
show(&people);
break;
}
case 6:
{
clear(&people);
break;
}
default:
{
return 0;
break;
}
}
}
return 0;
}
這樣就實現(xiàn)了一個簡單的通訊錄。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
OpenCV數(shù)字圖像處理基于C++之圖像形態(tài)學(xué)處理詳解
OpenCV是一款由Intel公司俄羅斯團隊發(fā)起并參與和維護的一個計算機視覺處理開源軟件庫,支持與計算機視覺和機器學(xué)習(xí)相關(guān)的眾多算法,下面這篇文章主要給大家介紹了關(guān)于OpenCV數(shù)字圖像處理基于C++之圖像形態(tài)學(xué)處理的相關(guān)資料,需要的朋友可以參考下2022-12-12
數(shù)據(jù)結(jié)構(gòu)課程設(shè)計- 解析最少換車次數(shù)的問題詳解
數(shù)據(jù)結(jié)構(gòu)課程設(shè)計- 解析最少換車次數(shù)的問題詳解2013-05-05
MinGW-w64 C/C++編譯器下載和安裝的方法步驟(入門教程)
如果電腦沒有安裝MinGW-w64 C/C++編譯器,就無法運行g(shù)cc命令,本文主要介紹了MinGW-w64 C/C++編譯器下載和安裝的方法步驟,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02

