C語言實(shí)現(xiàn)通訊錄的詳細(xì)代碼
(一)實(shí)現(xiàn)思路
1.通訊錄功能
添加好友,刪除好友,查找好友,修改好友信息,對(duì)好友進(jìn)行排序
2.模塊化實(shí)現(xiàn)各方面的功能
a. test.c
測(cè)試通訊錄功能
b. Contact.c
實(shí)現(xiàn)通訊錄功能
c. Contact.h
包含通訊錄實(shí)現(xiàn)的頭文件
3.代碼實(shí)現(xiàn)
(二)源代碼
A.test.c
#define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <stdlib.h> #include <string.h> #include "contact.h" void menu() { printf("*******************************\n"); printf("*** 1.Add 2.Del ***\n"); printf("*** 3.Search 4.Modify ***\n"); printf("*** 5.Show 6.Sort ***\n"); printf("*** 7.Help 8.About0 ***\n"); printf("*** 0.Exit ***\n"); printf("*******************************\n"); } int main() { int input = 0; //創(chuàng)建通訊錄 int size = 0; struct Contact con;//一個(gè)結(jié)構(gòu)體里包含1000個(gè)人的信息和size; //size表示的是該通訊錄里現(xiàn)在的好友數(shù) //初始化通訊錄 InitContact(&con);//使size的初始值,以及好友信息初始化為0; do { menu(); printf("請(qǐng)選擇:"); 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 Sort: SortContact(&con); break; //退出 case Exit: printf("退出通訊錄!"); break; //通訊錄的使用以及幫助 case Help: HelpContact(); break; //關(guān)于通訊錄 case About: AboutContact(); break; //選擇錯(cuò)誤 default: printf("選擇錯(cuò)誤!"); break; } } while (input); return 0; }
B.Contact.h
#define _CRT_SECURE_NO_WARNINGS 1 #define Max 1000 #define Max_name 20 #define Max_sex 5 #define Max_tele 12 #define Max_addr 30 enum Option { Exit, Add, Del, Search, Modify, Show, Sort, Help, About }; //創(chuàng)建一個(gè)結(jié)構(gòu)體來存放通訊錄中要存放的信息 struct PeoInfo { char name[Max_name]; int age; char sex[Max_sex]; char tele[Max_tele]; char addr[Max_addr]; }; //通訊錄類型 struct Contact { struct PeoInfo data[Max];//存放一個(gè)信息,包括好友姓名,年齡,性別,電話,地址 int size;//記錄當(dāng)前已經(jīng)有的元素個(gè)數(shù) //存入一個(gè)好友,size加1,表示通訊錄人數(shù)增加一個(gè) }; //聲明函數(shù) //1.對(duì)通訊錄進(jìn)行初始化 void InitContact(struct Contact* ps); //增加好友信息 void AddContact(struct Contact* ps); //刪除好友 void DelContact(struct Contact* ps); //查找指定姓名的好友 void SearchContact(struct Contact* ps); //顯示好友信息 void ShowContact(const struct Contact* ps); //修改好友信息 void ModifyContact( struct Contact* ps); //按名字首字母對(duì)通訊錄的好友進(jìn)行排序 void SortContact( struct Contact* ps); //幫助使用通訊錄 void HelpContact(); //關(guān)于通訊錄 void AboutContact();
C.Contact.c
#define _CRT_SECURE_NO_WARNINGS 1 #include "contact.h" #include <stdio.h> #include <stdlib.h> #include <string.h> //初始化通訊錄 void InitContact(struct Contact* ps) { memset(ps->data, 0, sizeof(ps->data)); ps->size = 0;//設(shè)置通訊錄最初只有0個(gè)元素 } //幫助使用通訊錄 void HelpContact() { printf("各按鍵的使用:\n"); printf("1.添加好友\n"); printf("2.刪除好友\n"); printf("3.查找好友信息\n"); printf("4.修改好友信息\n"); printf("5.顯示好友信息\n"); printf("6.對(duì)好友進(jìn)行排序\n"); printf("7.幫助使用通訊錄\n"); printf("8.關(guān)于通訊錄\n"); printf("謝謝使用通訊錄!\n"); } //關(guān)于通訊錄 void AboutContact() { printf("通訊錄一般指在日常生活中用筆記錄,也在手機(jī),電腦,電子字典等電子產(chǎn)品中擁有這個(gè)功能。\n"); } //增加好友的電話,信息 void AddContact(struct Contact* ps) { if (ps->size == Max) { printf("通訊錄已滿,無法增加!\n"); } else { printf("請(qǐng)輸入姓名:"); scanf("%s", ps->data[ps->size].name); //除了年齡,其他都是數(shù)組,直接用數(shù)組名 printf("請(qǐng)輸入年齡:"); scanf("%d", &(ps->data[ps->size].age)); //年齡不是數(shù)組,則需要& printf("請(qǐng)輸入性別:"); scanf("%s", ps->data[ps->size].sex); printf("請(qǐng)輸入電話:"); scanf("%s", ps->data[ps->size].tele); printf("請(qǐng)輸入地址:"); scanf("%s", ps->data[ps->size].addr); ps->size++; //添加成功一個(gè)1好友,size加1,; printf("添加成功!\n"); } } //在刪除,查找,修改的函數(shù)中均涉及查找到該好友才能進(jìn)行 //為了避免冗余,我們把查找的這個(gè)環(huán)節(jié)從函數(shù)中抽離出來 //在函數(shù)中直接使用,就不會(huì)顯得重復(fù) static int Find_by_name(struct Contact* ps, char name[Max_name]) { int i; for (i = 0; i < ps->size; i++) { //將要查找的好友姓名與通訊錄中的好友進(jìn)行比較 if (0 == strcmp(ps->data[i].name, name)) { //若找到,返回其下標(biāo) return i; } } //若都循環(huán),比對(duì)完了以后還沒找到就返回-1 return -1; } //刪除好友信息 void DelContact(struct Contact* ps) { int j; char name[Max_name]; printf("請(qǐng)輸入刪除好友的名字:"); scanf("%s", name); //1.查找要?jiǎng)h除的人的位置 int pos = Find_by_name(ps, name); //調(diào)用函數(shù)進(jìn)行查找,若找到,返回下標(biāo),若沒找到,返回-1; //2.刪除 if (pos==-1) { printf("該好友不存在!\n"); } else { //刪除數(shù)據(jù) for (j = pos; j < ps->size - 1; j++) { ps->data[j] = ps->data[j + 1]; //刪除數(shù)據(jù)后,后面的元素位置都改變,向前移動(dòng)一個(gè)位置; } ps->size--; //刪除一個(gè)好友,size-1. printf("刪除成功!\n"); } } //查找指定好友信息 void SearchContact(struct Contact* ps) { char name[Max_name]; printf("輸入要查找的好友姓名:"); scanf("%s", name); int pos = Find_by_name(ps, name); if (pos ==-1) { printf("該好友不存在!\n"); } else { printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年齡", "性別", "電話", "地址"); printf("%10s\t%4d\t%5s\t%12s\t%20s\n", ps->data[pos].name, ps->data[pos].age, ps->data[pos].sex, ps->data[pos].tele, ps->data[pos].addr); } } //修改好友信息 void ModifyContact(struct Contact* ps) { char name[Max_name]; printf("請(qǐng)輸入需要修改信息的好友姓名:"); scanf("%s", name); int pos=Find_by_name(ps, name); if (pos == -1) { printf("該用戶不存在!\n"); } else { printf("請(qǐng)輸入姓名:"); scanf("%s", ps->data[pos].name); printf("請(qǐng)輸入年齡:"); scanf("%d", &(ps->data[pos].age)); printf("請(qǐng)輸入性別:"); scanf("%s", ps->data[pos].sex); printf("請(qǐng)輸入電話:"); scanf("%s", ps->data[pos].tele); printf("請(qǐng)輸入地址:"); scanf("%s", ps->data[pos].addr); printf("修改成功!\n"); } } //顯示出好友的基本信息 void ShowContact(const struct Contact* ps) { if (ps->size == 0) { printf("通訊錄為空!\n"); } else { int i = 0; printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年齡", "性別", "電話", "地址"); for (i = 0; i < ps->size; i++) { printf("%10s\t%4d\t%5s\t%12s\t%20s\n", ps->data[i].name, ps->data[i].age, ps->data[i].sex, ps->data[i].tele, ps->data[i].addr); } } } //按照名字的首字母進(jìn)行排序 int cmp_stu_by_name(const void* e1, const void* e2) { return (strcmp(((struct Contact*)e1)->data->name, ((struct Contact*)e2)->data->name)); } //我們用qsort()函數(shù)對(duì)我們的好友按照名字首字母進(jìn)行排序 void SortContact( struct Contact* ps) { qsort(ps->data, ps->size, sizeof(ps->data[0]), cmp_stu_by_name); printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年齡", "性別", "電話", "地址"); int i; for (i = 0; i < ps->size; i++) { printf("%10s\t%4d\t%5s\t%12s\t%20s\n", ps->data[i].name, ps->data[i].age, ps->data[i].sex, ps->data[i].tele, ps->data[i].addr); } }
到此這篇關(guān)于C語言實(shí)現(xiàn)通訊錄的詳細(xì)代碼的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語言完整實(shí)現(xiàn)12種排序算法(小結(jié))
本文主要介紹了C語言完整實(shí)現(xiàn)12種排序算法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05C語言實(shí)現(xiàn)飛機(jī)票務(wù)系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)飛機(jī)票務(wù)系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12C++?OpenCV實(shí)現(xiàn)白平衡之完美反射算法
完美反射算法是白平衡各種算法中較常見的一種,比灰度世界算法更優(yōu)。本文將利用C++和OpenCV實(shí)現(xiàn)白平衡中的完美反射算法,需要的可以參考一下2022-05-05Matlab實(shí)現(xiàn)繪制有氣泡感的網(wǎng)絡(luò)圖
這篇文章主要介紹了如何利用Matlab實(shí)現(xiàn)繪制有氣泡感的網(wǎng)絡(luò)圖,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Matlab有一定的幫助,需要的可以參考一下2023-02-02VSstudio中scanf返回值被忽略的原因及解決方法(推薦)
這篇文章主要介紹了VSstudio中scanf返回值被忽略的原因及其解決方法,scanf返回值被忽略,接下來我就告訴大家該如何解決這個(gè)問題,需要的朋友可以參考下2022-09-09