教你C語言實現通訊錄的詳細程式碼
導讀 | 本文詳細講解了C語言實現通訊錄的方法,文中透過示例程式碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑑價值,需要的朋友可以參考下 |
(一)實現思路
1.通訊錄功能
新增好友,刪除好友,查詢好友,修改好友資訊,對好友進行排序
2.模組化實現各方面的功能
a. test.c
測試通訊錄功能
b. Contact.c
實現通訊錄功能
c. Contact.h
包含通訊錄實現的標頭檔案
3.程式碼實現
(二)原始碼
A.test.c
#define _CRT_SECURE_NO_WARNINGS 1 #include#include#include#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; //建立通訊錄 int size = 0; struct Contact con;//一個結構體裡包含1000個人的資訊和size; //size表示的是該通訊錄裡現在的好友數 //初始化通訊錄 InitContact(&con);//使size的初始值,以及好友資訊初始化為0; 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 Sort: SortContact(&con); break; //退出 case Exit: printf("退出通訊錄!"); break; //通訊錄的使用以及幫助 case Help: HelpContact(); break; //關於通訊錄 case About: AboutContact(); break; //選擇錯誤 default: printf("選擇錯誤!"); 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 }; //建立一個結構體來存放通訊錄中要存放的資訊 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];//存放一個資訊,包括好友姓名,年齡,性別,電話,地址 int size;//記錄當前已經有的元素個數 //存入一個好友,size加1,表示通訊錄人數增加一個 }; //宣告函式 //1.對通訊錄進行初始化 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); //按名字首字母對通訊錄的好友進行排序 void SortContact( struct Contact* ps); //幫助使用通訊錄 void HelpContact(); //關於通訊錄 void AboutContact();
C.Contact.c
#define _CRT_SECURE_NO_WARNINGS 1 #include "contact.h" #include#include#include//初始化通訊錄 void InitContact(struct Contact* ps) { memset(ps->data, 0, sizeof(ps->data)); ps->size = 0;//設定通訊錄最初只有0個元素 } //幫助使用通訊錄 void HelpContact() { printf("各按鍵的使用:\n"); printf("1.新增好友\n"); printf("2.刪除好友\n"); printf("3.查詢好友資訊\n"); printf("4.修改好友資訊\n"); printf("5.顯示好友資訊\n"); printf("6.對好友進行排序\n"); printf("7.幫助使用通訊錄\n"); printf("8.關於通訊錄\n"); printf("謝謝使用通訊錄!\n"); } //關於通訊錄 void AboutContact() { printf("通訊錄一般指在日常生活中用筆記錄,也在手機,電腦,電子字典等電子產品中擁有這個功能。\n"); } //增加好友的電話,資訊 void AddContact(struct Contact* ps) { if (ps->size == Max) { printf("通訊錄已滿,無法增加!\n"); } else { printf("請輸入姓名:"); scanf("%s", ps->data[ps->size].name); //除了年齡,其他都是陣列,直接用陣列名 printf("請輸入年齡:"); scanf("%d", &(ps->data[ps->size].age)); //年齡不是陣列,則需要& printf("請輸入性別:"); scanf("%s", ps->data[ps->size].sex); printf("請輸入電話:"); scanf("%s", ps->data[ps->size].tele); printf("請輸入地址:"); scanf("%s", ps->data[ps->size].addr); ps->size++; //新增成功一個1好友,size加1,; printf("新增成功!\n"); } } //在刪除,查詢,修改的函式中均涉及查詢到該好友才能進行 //為了避免冗餘,我們把查詢的這個環節從函式中抽離出來 //在函式中直接使用,就不會顯得重複 static int Find_by_name(struct Contact* ps, char name[Max_name]) { int i; for (i = 0; i < ps->size; i++) { //將要查詢的好友姓名與通訊錄中的好友進行比較 if (0 == strcmp(ps->data[i].name, name)) { //若找到,返回其下標 return i; } } //若都迴圈,比對完了以後還沒找到就返回-1 return -1; } //刪除好友資訊 void DelContact(struct Contact* ps) { int j; char name[Max_name]; printf("請輸入刪除好友的名字:"); scanf("%s", name); //1.查詢要刪除的人的位置 int pos = Find_by_name(ps, name); //呼叫函式進行查詢,若找到,返回下標,若沒找到,返回-1; //2.刪除 if (pos==-1) { printf("該好友不存在!\n"); } else { //刪除資料 for (j = pos; j < ps->size - 1; j++) { ps->data[j] = ps->data[j + 1]; //刪除資料後,後面的元素位置都改變,向前移動一個位置; } ps->size--; //刪除一個好友,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("請輸入需要修改資訊的好友姓名:"); scanf("%s", name); int pos=Find_by_name(ps, name); if (pos == -1) { printf("該使用者不存在!\n"); } else { printf("請輸入姓名:"); scanf("%s", ps->data[pos].name); printf("請輸入年齡:"); scanf("%d", &(ps->data[pos].age)); printf("請輸入性別:"); scanf("%s", ps->data[pos].sex); printf("請輸入電話:"); scanf("%s", ps->data[pos].tele); printf("請輸入地址:"); 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); } } } //按照名字的首字母進行排序 int cmp_stu_by_name(const void* e1, const void* e2) { return (strcmp(((struct Contact*)e1)->data->name, ((struct Contact*)e2)->data->name)); } //我們用qsort()函式對我們的好友按照名字首字母進行排序 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); } }
到此這篇關於C語言實現通訊錄的詳細程式碼的文章就介紹到這了。
原文來自:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69955379/viewspace-2851134/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 通訊錄的c語言程式編輯C語言
- C語言實現TCP通訊C語言TCP
- Go語言實現TCP通訊GoTCP
- C語言陣列實現約瑟夫環出圈問題 程式碼詳細註釋 簡單易懂C語言陣列
- 【C語言進階】通訊錄的儲存和載入C語言
- 【大語言模型基礎】60行Numpy教你實現GPT-原理與程式碼詳解模型GPT
- C語言實現通訊錄管理系統(結構體、列舉、聯合體應用)C語言結構體
- 詳解 CmProcess 跨程式通訊的實現
- 通訊錄管理系統(C++實現)C++
- UDP內網穿透和打洞原理的C語言程式碼實現UDP內網穿透C語言
- C語言運算子深度解析--超詳細C語言
- C語言/C++程式設計學習:棧的程式碼實現之陣列方案C語言C++程式設計陣列
- ffmpeg播放器開發 詳細記錄+程式碼實現3播放器
- C語言簡單程式碼程式C語言
- 教你如何用python實現學生通訊錄管理系統Python
- C 語言程式碼總結
- 邏輯式程式語言極簡實現(使用C#) - 4. 程式碼實現(完結)C#
- Aidl程式間通訊詳細介紹AI
- C語言如何實現泛型程式設計?C語言泛型程式設計
- c語言實用小程式C語言
- 掃雷--C語言實現C語言
- c語言實現階乘C語言
- HTTPS通訊的C++實現HTTPC++
- 聊聊C語言/C++—程式和程式語言C語言C++
- C語言 二維陣列實現三子棋的思路及程式碼C語言陣列
- 手拉手教你實現一門程式語言 Enkel, 系列 11
- 手拉手教你實現一門程式語言 Enkel, 系列 10
- 手拉手教你實現一門程式語言 Enkel, 系列 9
- 手拉手教你實現一門程式語言 Enkel, 系列 8
- 手拉手教你實現一門程式語言 Enkel, 系列 7
- 手拉手教你實現一門程式語言 Enkel, 系列 6
- 手拉手教你實現一門程式語言 Enkel, 系列 5
- 手拉手教你實現一門程式語言 Enkel, 系列 4
- 手拉手教你實現一門程式語言 Enkel, 系列 3
- 手拉手教你實現一門程式語言 Enkel, 系列 2
- 手拉手教你實現一門程式語言 Enkel, 系列 1
- 手拉手教你實現一門程式語言 Enkel, 系列 20
- 手拉手教你實現一門程式語言 Enkel, 系列 19