C語言通過三種方法實現(xiàn)屬于你的通訊錄
一、基礎(chǔ)版本
前提準(zhǔn)備:
1、通訊錄里面的人的個人信息(姓名、性別、年齡、手機號、地址)。
2、通訊錄名單(來實現(xiàn)人員的增刪插改)。
3、人員的初始化。
4、菜單。
1.1 通訊錄的個人信息(結(jié)構(gòu)體來實現(xiàn))
typedef struct peoInfo //重定義 { char name[20]; //姓名 int age ; //年齡 char sex[10]; //性別 char tele[12]; //手機號 char addr[30]; //地址 }peoInfo;
1.2通訊錄名單
typedef struct Contact { peoInfo data[100]; //人員名單 結(jié)構(gòu)體數(shù)組 int count; //人員數(shù)量 }Contact;
1.3人員初始化
void InitContact(Contact* con) { assert(con); con->count=0; //初始人數(shù)為0 memset(con->data,0,sizeof(con->data)); //這是一個c語言的庫函數(shù)把數(shù)組里面的數(shù)全部初始化為0 }
1.4菜單
void menu(void) { printf("===============================\n"); printf("====1.add 2. del 3.serch=====\n"); printf("=====4.modify 5.show======\n"); printf("=====6.sort 0.exit======\n"); printf("===============================\n"); printf("===============================\n"); }
1.5主函數(shù)
enum a { ext, //這里用了簡單的枚舉的方法 枚舉的初始值為0 add, del, serch, modify, show, sort }; int main() { int choice; Contact con; //通訊錄 do { menu(); printf("請選擇功能\n"); scanf("%d",&choice); switch(choice) { case add: AddContact(&con); //實現(xiàn)增加功能的函數(shù) break ; case del: DelContanct(&con); //實現(xiàn)刪除功能的函數(shù) break ; case serch: SerContact(&con); //實現(xiàn)查找功能的函數(shù) break ; case modify: ModContact(& con); //實現(xiàn)修改功能的函數(shù) break ; case show: ShowContact(&con); //實現(xiàn)展示功能的函數(shù) break ; case sort: SorContact(&con); //實現(xiàn)排序功能的函數(shù) break ; case ext : printf("程序結(jié)束\n"); break; default : printf("輸入有誤請重新輸入\n"); } }while(choice); return 0; }
二、功能的實現(xiàn)
2.1、增加人數(shù)
void AddContact(Contact* con) { assert(con); //指針不能為空 if(con->count==Max) { printf("存放已滿\n"); return ; } printf("請輸入名字"); scanf("%s",con->data[con->count].name); printf("請輸入年齡"); scanf("%d",&(con->data[con->count].age)); printf("請輸入性別"); scanf("%s",con->data[con->count].sex); printf("請輸入電話"); scanf("%s",con->data[con->count].tele); printf("請輸入地址"); scanf("%s",con->data[con->count].addr); con->count++; printf("增加成功\n"); }
2.2、刪除人數(shù)
static int xiaomafind(Contact* con,char name[]) { assert(con); int i=0; for(i=0;i<con->count;i++) { if(0==strcmp(con->data[i].name,name)) //通過名字來查找看是否存在 ,如果有返回下標(biāo)。 { return i; } else { return -1; } } void DelContanct(Contact* con) { char name[20]={0}; printf("請輸入你想刪除的名字\n"); assert(con); int i; scanf("%s",name); int pos=xiaomafind(con,name); if(pos==-1) { printf("沒有你要刪除的人\n"); } else { for(i=pos;i<con->count;i++) { con->data[i]=con->data[i+1]; //通過數(shù)組后一個覆蓋前一個來完成刪除功能 } con->count--; //刪除完成后人員減一 printf("刪除成功\n"); } }
2.3、查找
static int xiaomafind(Contact* con,char name[]) { assert(con); int i=0; for(i=0;i<con->count;i++) { if(0==strcmp(con->data[i].name,name)) { return i; } } return -1; } void SerContact(Contact *con) { char name[20]={0}; printf("請輸入你想查找的名字\n"); assert(con); scanf("%s",name); int find =xiaomafind(con,name); if(find==-1) { printf("沒有你要查找的用戶\n"); } else{ printf("查找成功\n"); } }
2.4、展示
void ShowContact( const Contact* con) { assert(con); int i; for(i=0;i<con->count;i++) { printf("%2s\t%3d\t%5s\t%12s\t%30s\n",con->data[i].name,con->data[i].age,con->data[i].sex,con->data[i].tele,con->data[i].addr); //這里是為了打印好看 } }
2.5、排序(這里我是通過名字)
^?_?^用qsort 函數(shù)發(fā)現(xiàn)很很容的都能進行排序,我們只需要告訴他我們的排序方法是什么就可以很容易的進行一下排序
int cmp_stu_by_name(const void*e1,const void*e2) { return strcmp(((peoInfo*)e1)->name,((peoInfo*)e2)->name); } //如不不理解的看我指針講解中回調(diào)函數(shù) void SorContact(Contact* con) { assert(con); qsort(con->data, con->count, sizeof(peoInfo), cmp_stu_by_name); //這里運用了一個c語言的庫函數(shù)qsort函數(shù),在指針進階中我也講述了如何使用,如果不會的可以看一下指針的進階。 }
三、通訊錄進階(設(shè)置動態(tài)存儲)
動態(tài)版本只需要改三個位置就行啦
3.1通訊錄從靜態(tài)改為動態(tài)
//靜態(tài)版本 //typedef struct Contact //{ // peoInfo data[100]; //人員名單 結(jié)構(gòu)體數(shù)組 // int count; //人員數(shù)量 //}Contact; //動態(tài)版本 ???????typedef struct Contact { peoInfo *data; //人員名單 結(jié)構(gòu)體指針 int count; //人員數(shù)量 int capicity; //通訊錄容量 }Contact;
3.2通訊錄的初始化
//靜態(tài)版本 //void InitContact(Contact* con) //{ // assert(con); // con->count=0; //初始人數(shù)為0 // memset(con->data,0,sizeof(con->data)); //這是一個c語言的庫函數(shù)把數(shù)組里面的數(shù)全部初始化為0 //} //動態(tài)版本 void InitContact(Contact* con) { assert(con); con->count=0; con->data=(PeoInf0*)calloc(3,sizeof(peoInfo*)); if(con->data=NULL) { perrror("con->data"); //如果空指針打印錯誤原因 } con->capicity=3; //這里我們設(shè)置的初始容量為3 }
3.3通訊錄的增加需要判斷是否滿了
void AddContact(Contact* con) { assert(con); //指針不能為空 if(con->count==con->capicity) { (peoInfo*)ptr=(PeoInfo*)realloc(con->data,(con->capicity)*2*sizeof(peoInfo)). //增加人數(shù)前先進行判斷是否滿了,如果滿了擴大2倍。 if(ptr==NULL) { perror("peoInof"); return ; } else{ con->data=ptr; } } printf("請輸入名字"); scanf("%s",con->data[con->count].name); printf("請輸入年齡"); scanf("%d",&(con->data[con->count].age)); printf("請輸入性別"); scanf("%s",con->data[con->count].sex); printf("請輸入電話"); scanf("%s",con->data[con->count].tele); printf("請輸入地址"); scanf("%s",con->data[con->count].addr); con->count++; printf("增加成功\n"); }
^ - ^這樣我們就實現(xiàn)通訊錄的動態(tài)化,就不怕通訊錄人數(shù)會存滿了。
四、文件的形式存儲通訊錄
前面的通訊錄在程序結(jié)束后發(fā)現(xiàn)人員沒有辦法進行一個保存,而通過文件的形式我們可以很好的做到這一點,在結(jié)束之前進行對文件的保存,在再一次執(zhí)行程序是輸入保存的文件,但是文件操作也有自己的不足之處,后面用數(shù)據(jù)庫來實現(xiàn)更好,當(dāng)前我們先用文件的形式來進行實現(xiàn)數(shù)據(jù)的保存,而實現(xiàn)這個只需要在結(jié)束時對文件保存,在初始化的時候時文件信息流入。
4.1人員信息的保存
void SaveContact(Contact*con) { assert(con); //通過二進制寫的形式把人員數(shù)據(jù)寫入當(dāng)中 FILE* pfWrite=fopen("Contact.txt","wb"); if(pfWrite==NULL) { perror("SaveContact"); return ; } int i=0; for(i=0;i<con->count;i++) { fwrite(con->data+i,sizeof(peoInfo),1,pfWrite); //一次寫一個人員 } fclose(pfWrite); pfWrite=NULL; }
4.2人員信息的流入
void LoadContact(Contact* con) { assert(con); FILE*pfread =fopen("/Users/mamenghao/Desktop/Contact.txt","rb"); //二進制來讀取文件信息 if(pfread==NULL) { perror("LoadContact"); return ; } peoInfo tmp={0}; //創(chuàng)建一個人員結(jié)構(gòu)體變量先做臨時的保存 while( fread(&tmp,sizeof(peoInfo),1,pfread)==1) { if(con->count==con->capicity) { peoInfo* ptr=(peoInfo*)realloc(con->data,((con->capicity)*2*sizeof(peoInfo))); if(ptr==NULL) { perror("peoInof"); return ; } else{ con->data=ptr; } } //在增加前先判斷是否容量已經(jīng)滿了 con->data[con->count]=tmp; con->count++; } fclose(pfread); pfread=NULL; }
總結(jié):
通訊錄本身實現(xiàn)它并不是特別的難,運用的知識就是順序表的增刪插改功能,而進一步的優(yōu)化只需要大家熟練掌握文件的操作和動態(tài)內(nèi)存存儲就能很好的實現(xiàn)啦!!
到此這篇關(guān)于C語言通過三種方法實現(xiàn)屬于你的通訊錄的文章就介紹到這了,更多相關(guān)C語言通訊錄內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Qt數(shù)據(jù)庫相關(guān)應(yīng)用開發(fā)總結(jié)
這篇文章主要為大家介紹了在Qt數(shù)據(jù)庫應(yīng)用開發(fā)中的一些經(jīng)驗總結(jié),以及一些組件的使用介紹。文中的示例代碼講解詳細(xì),需要的可以參考一下2022-02-02深入探索C++中stack和queue的底層實現(xiàn)
這篇文章主要介紹了C++中的stack和dequeue的底層實現(xiàn),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-09-09