C語言實(shí)現(xiàn)通訊錄程序
本文實(shí)例為大家分享了C語言實(shí)現(xiàn)通訊錄程序的具體代碼,供大家參考,具體內(nèi)容如下
設(shè)計(jì)要求:
可以存放1000個(gè)人的信息,每個(gè)人的信息包括姓名、年齡、性別、電話、住址
通訊錄功能包括:
1.增加聯(lián)系人
2.刪除指定聯(lián)系人
3.查找指定聯(lián)系人
4.修改指定聯(lián)系人
5.顯示所有聯(lián)系人
6.退出通訊錄
思路分析:
首先我們需要創(chuàng)建3個(gè)文件,分別是源文件(test.c)、通訊錄文件(contact.c)、通訊錄頭文件(contact.h),其中頭文件用來包含頭文件、聲名信息、結(jié)構(gòu)體、創(chuàng)建全局變量以及宏。
我們一步一步完成這個(gè)程序:
1.在源程序中寫一個(gè)菜單函數(shù)menu()以及聯(lián)合體Option,當(dāng)然這個(gè)時(shí)候還沒有引頭文件,不可以運(yùn)行。菜單函數(shù)menu()中清楚的標(biāo)明每個(gè)數(shù)字對應(yīng)的功能,分別是 1.增加聯(lián)系人 2.刪除指定聯(lián)系人 3.查找指定聯(lián)系人 4.修改指定聯(lián)系人 5.顯示所有聯(lián)系人 0.退出通訊錄。在聯(lián)合體中相應(yīng)的成員對應(yīng)數(shù)字0~5。
void menu() { printf("\n"); printf("**************************************\n"); printf("****** 1. add 2. del ******\n"); printf("****** 3. search 4.modify ******\n"); printf("****** 5. show 0. exit ******\n"); printf("**************************************\n"); } enum Option { EXIT, //0 ADD, //1 DEL, //2 SEARCH, //3 MODIFY, //4 SHOW //5 };
2.寫主函數(shù)main(),定義input代表要輸入的數(shù),在do while循環(huán)中首先調(diào)用菜單函數(shù)menu(),然后請你輸入一個(gè)數(shù)字,再用switch語句對應(yīng)相應(yīng)的功能,在之前我們說過聯(lián)合體的成員就代表數(shù)字0~5,所以case ADD == case case 1,以此類推。相應(yīng)的選擇對應(yīng)相應(yīng)功能的函數(shù),如果你選了1,則進(jìn)入case ADD,然后調(diào)用AddContact(),傳參&con,當(dāng)然這個(gè)函數(shù)要在后面進(jìn)行創(chuàng)建。con是什么也在后面解釋。
int main() { int input = 0; struct Contact con;//創(chuàng)建一個(gè)通訊錄 InitContact(&con);//初始化通訊錄 do { menu(); printf("請選擇:"); scanf("%d", &input); switch (input) { case ADD: AddContact(&con); break; case DEL: DelContact(&con); break; case SEARCH: SearchContact(&con); break; case MODIFY: ModifyContact(&con); break; case SHOW: ShowContact(&con); break; case EXIT: printf("退出通訊錄\n"); break; default: printf("選擇錯誤\n"); break; } } while (input); return 0; }
3.創(chuàng)建頭文件contact.h,定義結(jié)構(gòu)體類型struct PeoInfo和struct Contact。前者是一個(gè)人的信息,創(chuàng)建了他的結(jié)構(gòu)體類型變量代表創(chuàng)建了一個(gè)人的信息;后者是一個(gè)通訊錄的數(shù)據(jù),創(chuàng)建一個(gè)struct Contact類型的變量包括一個(gè)存放1000個(gè)數(shù)據(jù)的struct PeoInfo類型數(shù)組data[],再定義一個(gè)sz用來計(jì)算存放人數(shù)。當(dāng)然我們看到數(shù)組中的符號是#define定義的宏,用來替換那些數(shù)字。之前看到的con是創(chuàng)建的一個(gè)struct Contact類型變量,并且將他初始化。
#define NAME_MAX 30 #define SEX_MAX 5 #define TELE_MAX 12 #define ADDR_MAX 30 #define MAX 1000 struct PeoInfo { char name[NAME_MAX]; //姓名 int age; //年齡 char sex[SEX_MAX]; //性別 char tele[TELE_MAX]; //電話 char addr[ADDR_MAX]; //住址 }; struct Contact { struct PeoInfo data[MAX];//1000個(gè)人的數(shù)據(jù)存放在data數(shù)組中 int sz;//通訊錄中當(dāng)前有效元素個(gè)數(shù) };
4.引用頭文件,并聲明函數(shù)。至此,contact.h就寫完了,因?yàn)檫@個(gè)頭文件已經(jīng)引用了接下來需要用到的#include <stdio.h>和#include <string.h>,所以直接在test.c中引用#include "contact.h"就可以。
#define NAME_MAX 30 #define SEX_MAX 5 #define TELE_MAX 12 #define ADDR_MAX 30 #define MAX 1000 #include <stdio.h> #include <string.h> struct PeoInfo { char name[NAME_MAX]; int age; char sex[SEX_MAX]; char tele[TELE_MAX]; char addr[ADDR_MAX]; }; struct Contact { struct PeoInfo data[MAX];//1000個(gè)人的數(shù)據(jù)存放在data數(shù)組中 int sz;//通訊錄中當(dāng)前有效元素個(gè)數(shù) }; void AddContact(struct Contact* pc);//增加聯(lián)系人 void DelContact(struct Contact* pc);//刪除指定聯(lián)系人 void SearchContact(struct Contact* pc);//查找指定聯(lián)系人 void ModifyContact(struct Contact* pc);//修改指定聯(lián)系人 void ShowContact(struct Contact* pc);//顯示所有聯(lián)系人
5.寫contact.c也就是通訊錄的具體實(shí)現(xiàn)。首先引頭文件#include "contact.h",然后寫初始化函數(shù)InitContact()。用一個(gè)結(jié)構(gòu)體指針接受(1000個(gè)容量)。將sz賦值為0,數(shù)組全部成員賦值為0,用到memset函數(shù),頭文件#include <string>我們之前已經(jīng)引過了。
#include "contact.h" void InitContact(struct Contact* pc) { pc->sz = 0;//默認(rèn)沒有信息 memset(pc->data, 0, sizeof(pc->data)); }
6.接下來寫各個(gè)功能的函數(shù):
AddContact()增加聯(lián)系人,輸入信息至指針指向的數(shù)組的第sz位的相應(yīng)成員。sz初始為0,剛好對應(yīng)數(shù)組第0位。
void AddContact(struct Contact* pc) { if (pc->sz == MAX) { printf("通訊錄已滿,無法添加信息\n"); } else { printf("請輸入名字:"); scanf("%s", pc->data[pc->sz].name); printf("請輸入年齡:"); scanf("%d", &(pc->data[pc->sz].age)); printf("請輸入性別:"); scanf("%s", pc->data[pc->sz].sex); printf("請輸入電話:"); scanf("%s", pc->data[pc->sz].tele); printf("請輸入住址:"); scanf("%s", pc->data[pc->sz].addr); printf("添加成功\n"); pc->sz++; } }
DelContact()刪除指定聯(lián)系人,如果sz不為0,說明通訊錄中有信息,可以進(jìn)行刪除。輸入名字后需進(jìn)行查找,這里通過寫一個(gè)遍歷查找姓名函數(shù)FindContactByName()進(jìn)行查找,其中使用庫函數(shù)strcmp(字符串比較函數(shù)),如果相等則返回?cái)?shù)組下標(biāo)pos,然后在DelContact()從第pos位開始循環(huán),將后一位的值賦給前一位,代表刪除成功,然后sz--。
int FindContactByName(const struct Contact* pc, const char* name) { int i = 0; for (i = 0; i < pc->sz; i++) { if (strcmp(pc->data[i].name, name) == 0) { return i; } } return -1; } void DelContact(struct Contact* pc) { if (pc->sz == 0) { printf("通訊錄為空,無法刪除\n"); return; } char name[NAME_MAX] = { 0 }; printf("請輸入要刪除人的名字:"); scanf("%s", name); //查找 int pos = FindContactByName(pc, name); if (pos == -1) { printf("指定的聯(lián)系人不存在\n"); } else { //刪除 int j = 0; for (j = pos; j < pc->sz-1; j++) { pc->data[j] = pc->data[j + 1]; } pc->sz--; printf("刪除成功\n"); } }
SearchContact()查找指定聯(lián)系人,直接調(diào)用FindContactByName(),找到后打印信息。
void SearchContact(const struct Contact* pc) { char name[NAME_MAX] = { 0 }; printf("請輸入要查找人名字:"); scanf("%s", name); int pos = FindContactByName(pc, name); if (pos == -1) { printf("查無此人\n"); } else { printf("%15s\t%5s\t%8s\t%15s\t%30s\n", "name", "age", "sex", "tele", "addr"); printf("%15s\t%5d\t%8s\t%15s\t%30s\n", pc->data[pos].name, pc->data[pos].age, pc->data[pos].sex, pc->data[pos].tele, pc->data[pos].addr); } }
ModifyContac()修改指定聯(lián)系人,使用FindContactByName()查找,如果存在的話返回?cái)?shù)組下標(biāo)pos,然后輸入新的信息覆蓋到指針指向下標(biāo)為pos的數(shù)組data的相應(yīng)成員。
void ModifyContact(struct Contact* pc) { char name[NAME_MAX] = { 0 }; printf("請輸入要修改人的名字:"); scanf("%s", name); int pos = FindContactByName(pc, name); if (pos == -1) { printf("要修改的人不存在\n"); } else { printf("請輸入新的名字:"); scanf("%s", pc->data[pos].name); printf("請輸入新的年齡:"); scanf("%d", &(pc->data[pos].age)); printf("請輸入新的性別:"); scanf("%s", pc->data[pos].sex); printf("請輸入新的電話:"); scanf("%s", pc->data[pos].tele); printf("請輸入新的住址:"); scanf("%s", pc->data[pos].addr); printf("修改成功"); } }
ShowContact()顯示所有聯(lián)系人,進(jìn)入函數(shù)先打印一行表頭,用“\t”分隔開,然后用for循環(huán)打印每一個(gè)人的數(shù)據(jù),直到第sz個(gè)人停下來。
void ShowContact(struct Contact* pc) { int i = 0; printf("%15s\t%5s\t%8s\t%15s\t%30s\n","name","age","sex","tele","addr"); for (i = 0; i < pc->sz; i++) { printf("%15s\t%5d\t%8s\t%15s\t%30s\n", pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr); } }
寫到這里就已經(jīng)全部完成了通訊錄程序的制作,下面展示所有的代碼:
test.c
#include "contact.h" void menu() { printf("\n"); printf("**************************************\n"); printf("****** 1. add 2. del ******\n"); printf("****** 3. search 4.modify ******\n"); printf("****** 5. show 0. exit ******\n"); printf("**************************************\n"); } enum Option { EXIT, ADD, DEL, SEARCH, MODIFY, SHOW }; int main() { int input = 0; struct Contact con;//創(chuàng)建一個(gè)通訊錄 InitContact(&con);//初始化通訊錄 do { menu(); printf("請選擇:"); scanf("%d", &input); switch (input) { case ADD: AddContact(&con); break; case DEL: DelContact(&con); break; case SEARCH: SearchContact(&con); break; case MODIFY: ModifyContact(&con); break; case SHOW: ShowContact(&con); break; case EXIT: printf("退出通訊錄\n"); break; default: printf("選擇錯誤\n"); break; } } while (input); return 0; }
contact.c
#include "contact.h" void InitContact(struct Contact* pc) { pc->sz = 0;//默認(rèn)沒有信息 memset(pc->data, 0, sizeof(pc->data)); } void AddContact(struct Contact* pc) { if (pc->sz == MAX) { printf("通訊錄已滿,無法添加信息\n"); } else { printf("請輸入名字:"); scanf("%s", pc->data[pc->sz].name); printf("請輸入年齡:"); scanf("%d", &(pc->data[pc->sz].age)); printf("請輸入性別:"); scanf("%s", pc->data[pc->sz].sex); printf("請輸入電話:"); scanf("%s", pc->data[pc->sz].tele); printf("請輸入住址:"); scanf("%s", pc->data[pc->sz].addr); printf("添加成功\n"); pc->sz++; } } int FindContactByName(const struct Contact* pc, const char* name) { int i = 0; for (i = 0; i < pc->sz; i++) { if (strcmp(pc->data[i].name, name) == 0) { return i; } } return -1; } void DelContact(struct Contact* pc) { if (pc->sz == 0) { printf("通訊錄為空,無法刪除\n"); return; } char name[NAME_MAX] = { 0 }; printf("請輸入要刪除人的名字:"); scanf("%s", name); //查找 int pos = FindContactByName(pc, name); if (pos == -1) { printf("指定的聯(lián)系人不存在\n"); } else { //刪除 int j = 0; for (j = pos; j < pc->sz-1; j++) { pc->data[j] = pc->data[j + 1]; } pc->sz--; printf("刪除成功\n"); } } void SearchContact(const struct Contact* pc) { char name[NAME_MAX] = { 0 }; printf("請輸入要查找人名字:"); scanf("%s", name); int pos = FindContactByName(pc, name); if (pos == -1) { printf("查無此人\n"); } else { printf("%15s\t%5s\t%8s\t%15s\t%30s\n", "name", "age", "sex", "tele", "addr"); printf("%15s\t%5d\t%8s\t%15s\t%30s\n", pc->data[pos].name, pc->data[pos].age, pc->data[pos].sex, pc->data[pos].tele, pc->data[pos].addr); } } void ModifyContact(struct Contact* pc) { char name[NAME_MAX] = { 0 }; printf("請輸入要修改人的名字:"); scanf("%s", name); int pos = FindContactByName(pc, name); if (pos == -1) { printf("要修改的人不存在\n"); } else { printf("請輸入新的名字:"); scanf("%s", pc->data[pos].name); printf("請輸入新的年齡:"); scanf("%d", &(pc->data[pos].age)); printf("請輸入新的性別:"); scanf("%s", pc->data[pos].sex); printf("請輸入新的電話:"); scanf("%s", pc->data[pos].tele); printf("請輸入新的住址:"); scanf("%s", pc->data[pos].addr); printf("修改成功"); } } void ShowContact(struct Contact* pc) { int i = 0; printf("%15s\t%5s\t%8s\t%15s\t%30s\n","name","age","sex","tele","addr"); for (i = 0; i < pc->sz; i++) { printf("%15s\t%5d\t%8s\t%15s\t%30s\n", pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr); } }
contact.h
#define NAME_MAX 30 #define SEX_MAX 5 #define TELE_MAX 12 #define ADDR_MAX 30 #define MAX 1000 #include <stdio.h> #include <string.h> struct PeoInfo { char name[NAME_MAX]; int age; char sex[SEX_MAX]; char tele[TELE_MAX]; char addr[ADDR_MAX]; }; struct Contact { struct PeoInfo data[MAX];//1000個(gè)人的數(shù)據(jù)存放在data數(shù)組中 int sz;//通訊錄中當(dāng)前有效元素個(gè)數(shù) }; void AddContact(struct Contact* pc);//增加聯(lián)系人 void DelContact(struct Contact* pc);//刪除指定聯(lián)系人 void SearchContact(struct Contact* pc);//查找指定聯(lián)系人 void ModifyContact(struct Contact* pc);//修改指定聯(lián)系人 void ShowContact(struct Contact* pc);//顯示所有聯(lián)系人
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
VC++實(shí)現(xiàn)添加文件關(guān)聯(lián)的方法示例
這篇文章主要介紹了VC++實(shí)現(xiàn)添加文件關(guān)聯(lián)的方法,涉及VC++針對注冊表的寫入與VC事件響應(yīng)相關(guān)操作技巧,需要的朋友可以參考下2017-08-08使用C++和Crypto++庫實(shí)現(xiàn)AES加密與解密
在這篇博客中,我們將深入探討如何利用C++和Crypto++庫實(shí)現(xiàn)高效且安全的AES加密與解密機(jī)制,Crypto++是一款高度認(rèn)可的免費(fèi)C++類庫,文中通過代碼示例介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下2024-01-01C語言創(chuàng)建鏈表錯誤之通過指針參數(shù)申請動態(tài)內(nèi)存實(shí)例分析
這篇文章主要介紹了C語言創(chuàng)建鏈表錯誤之通過指針參數(shù)申請動態(tài)內(nèi)存,是鏈表創(chuàng)建過程中非常常見的經(jīng)典錯誤。實(shí)例中做了較為詳盡的分析,需要的朋友可以參考下2014-09-09C++迭代器介紹(iterator、const_iterator、reverse_interator、const_rev
這篇文章主要介紹了C++迭代器介紹(iterator、const_iterator、reverse_interator、const_reverse_interator),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02c++ 如何在libuv中實(shí)現(xiàn)tcp服務(wù)器
這篇文章主要介紹了c++ 如何在libuv中實(shí)現(xiàn)tcp服務(wù)器,幫助大家更好的理解和使用libuv,感興趣的朋友可以了解下2021-02-02