C語言簡易通訊錄的實現(xiàn)代碼
本文實例為大家分享了C語言簡易通訊錄的具體代碼,供大家參考,具體內(nèi)容如下
通訊錄的實現(xiàn):
一.介紹:
運用C語言的數(shù)組、指針、結(jié)構(gòu)體等相關(guān)知識:實現(xiàn)一個簡易的通訊錄:
此通訊錄的大概內(nèi)容為:
通訊錄可存儲1000個人的信息:
每個人的基本信息有:名字+ 年齡+性別 + 電話+ QQ + 地址
此通訊錄所具有的功能:增加+ 刪除 + 查詢 + 修改 + 排序 + 退出
此通訊錄在設(shè)計時:總共設(shè)計了三個文件:
contact.h: 類型的聲明和函數(shù)的聲明
contact.c:函數(shù)功能的具體實現(xiàn)
test.c: 測試文件
二.具體實現(xiàn):
1. contact.h:
此文件中定義該通訊錄中所設(shè)計的功能的函數(shù)聲明以及兩個結(jié)構(gòu)體:
PeoInfo:存儲通訊錄中每個人的基本信息
Contact:存儲通訊錄中的數(shù)據(jù)以及通訊錄中的已存儲的人數(shù)
具體代碼實現(xiàn)如下:
// //類型的聲明+函數(shù)的聲明 // #include <stdio.h> #include <string.h> #define MAX 1000 #define MAX_NAME 20 #define MAX_TELE 12 #define MAX_ADDR 100 #define MAX_QQ 12 #define MAX_SEX 5 typedef struct PeoInfo { char name[MAX_NAME]; char tele[MAX_TELE]; char addr[MAX_ADDR]; char qq[MAX_QQ]; char sex[MAX_SEX]; short age; }PeoInfo; //通訊錄 typedef struct Contact { PeoInfo data[MAX];//數(shù)據(jù) int sz;//有效個數(shù) }Contact; //添加一個人的信息 void add_contact(Contact* pc); //顯示通訊錄中的信息 void show_contact(Contact* pc); //刪除指定的聯(lián)系人 void del_contact(Contact* pc); //查找指定聯(lián)系人 void search_contact(Contact* pc); //修改指定聯(lián)系人 void modify_contact(Contact* pc); //排序通訊錄的數(shù)據(jù) void sort_contact(Contact* pc);
2. contact.c:
此文件是該通訊錄所設(shè)計的功能的具體實現(xiàn):具體包括:
(1) 添加一個人的信息 void add_contact(Contact* pc);
(2)顯示通訊錄中的信息 void show_contact(Contact* pc);
(3)刪除指定的聯(lián)系人 void del_contact(Contact* pc);
(4)查找指定聯(lián)系人 void search_contact(Contact* pc);
(5)修改指定聯(lián)系人 void modify_contact(Contact* pc);
(6)排序通訊錄的數(shù)據(jù) void sort_contact(Contact* pc);
具體代碼實現(xiàn)如下:
#define _CRT_SECURE_NO_WARNINGS 1 #include "contact.h" void add_contact(Contact* pc) { if (pc->sz == MAX) { printf("通訊錄已滿\n"); } else { printf("請輸入名字:>"); scanf("%s", pc->data[pc->sz].name); printf("請輸入電話:>"); scanf("%s", pc->data[pc->sz].tele); printf("請輸入地址:>"); scanf("%s", pc->data[pc->sz].addr); printf("請輸入QQ:>"); scanf("%s", pc->data[pc->sz].qq); printf("請輸入性別:>"); scanf("%s", pc->data[pc->sz].sex); printf("請輸入年齡:>"); scanf("%d", &(pc->data[pc->sz].age)); pc->sz++; printf("添加成功\n"); } } void show_contact(Contact* pc) { int i = 0; printf("%10s %12s %20s %5s %12s %5s\n", "名字", "電話", "地址", "年齡", "QQ", "性別"); for (i = 0; i < pc->sz; i++) { printf("%10s %12s %20s %5d %12s %5s\n", pc->data[i].name, pc->data[i].tele, pc->data[i].addr, pc->data[i].age, pc->data[i].qq, pc->data[i].sex); } } static int find_peo_by_name(Contact* pc, char name[]) { int i = 0; for (i = 0; i < pc->sz; i++) { if (strcmp(name, pc->data[i].name) == 0) { return i;//找到了,返回下標 } } return -1;//找不到 } void del_contact(Contact* pc) { if (pc->sz == 0) { printf("抱歉,通訊錄為空\n"); } else { char name[MAX_NAME] = { 0 }; printf("請輸入要刪除人的名字:>"); scanf("%s", name); //1. 找到指定的聯(lián)系人的位置 int pos = find_peo_by_name(pc, name); if (pos == -1) { printf("很遺憾,刪除的人不存在\n"); } else { //2. 刪除 int j = 0; for (j = pos; j < pc->sz - 1; j++) { pc->data[j] = pc->data[j + 1]; } pc->sz--; printf("刪除成功\n"); } } } void search_contact(Contact* pc) { char name[MAX_NAME] = { 0 }; printf("請輸入要查找人的名字:>"); scanf("%s", name); int pos = find_peo_by_name(pc, name); if (pos == -1) { printf("查無此人\n"); } else { printf("%10s %12s %20s %5s %12s %5s\n", "名字", "電話", "地址", "年齡", "QQ", "性別"); printf("%10s %12s %20s %5d %12s %5s\n", pc->data[pos].name, pc->data[pos].tele, pc->data[pos].addr, pc->data[pos].age, pc->data[pos].qq, pc->data[pos].sex); } } void modify_contact(Contact* pc) { char name[MAX_NAME] = { 0 }; printf("請輸入要修改人的名字:>"); scanf("%s", name); int pos = find_peo_by_name(pc, name); if (pos == -1) { printf("查無此人\n"); } else { printf("請輸入新的名字:>"); scanf("%s", pc->data[pos].name); printf("請輸入新的電話:>"); scanf("%s", pc->data[pos].tele); printf("請輸入新的地址:>"); scanf("%s", pc->data[pos].addr); printf("請輸入新的QQ:>"); scanf("%s", pc->data[pos].qq); printf("請輸入新的性別:>"); scanf("%s", pc->data[pos].sex); printf("請輸入新的年齡:>"); scanf("%d", &(pc->data[pos].age)); } } void sort_contact(Contact* pc) { int i = 0; int j = 0; for (i = 0; i < pc->sz - 1; i++) { int flag = 1;//假設(shè)已經(jīng)有序 for (j = 0; j < pc->sz - 1 - i; j++) { if (strcmp(pc->data[j].name, pc->data[j + 1].name) > 0) { PeoInfo tmp = pc->data[j]; pc->data[j] = pc->data[j + 1]; pc->data[j + 1] = tmp; flag = 0; } } if (1 == flag) { break; } } }
3.test.c
此文件是對該通訊錄的功能實現(xiàn)的測試文件:包括菜單的打印,根據(jù)用戶的輸入,輸出相關(guān)信息以及該通訊錄功能的完整流程的實現(xiàn)等。
具體代碼實現(xiàn)如下:
#define _CRT_SECURE_NO_WARNINGS 1 #include "contact.h" //測試文件 //通訊錄1000個人的信息:名字+ 年齡+ 電話 + 地址+ QQ + 性別 //增 刪 查 改 排序 退出 #define _CRT_SECURE_NO_WARNINGS 1 void menu() { printf("*******************************\n"); printf("****** 1. add 2. del * ***\n"); printf("****** 3. search 4. modify ***\n"); printf("****** 5. sort 6. show ***\n"); printf("****** 0. exit ***\n"); printf("*******************************\n"); } enum Option { EXIT, ADD, DEL, SEARCH, MODIFY, SORT, SHOW }; //first_name //FirstName void test() { //創(chuàng)建的通訊錄 Contact con = { 0 }; int input = 0; do { menu(); printf("請選擇:>"); scanf("%d", &input); switch (input) { case ADD: add_contact(&con); break; case DEL: del_contact(&con); break; case SORT: sort_contact(&con); break; case SHOW: show_contact(&con); break; case SEARCH: search_contact(&con); break; case MODIFY: modify_contact(&con); break; case EXIT: printf("退出通訊錄\n"); break; default: printf("選擇錯誤\n"); break; } } while (input); } int main() { test();// return 0; }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
深入理解約瑟夫環(huán)的數(shù)學(xué)優(yōu)化方法
本篇文章是對約瑟夫環(huán)的數(shù)學(xué)優(yōu)化方法進行了詳細的分析介紹,需要的朋友參考下2013-05-05C++標準庫學(xué)習(xí)之weak_ptr智能指針用法詳解
這篇文章主要為大家詳細介紹了C++標準庫中weak_ptr智能指針用法的相關(guān)知識,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12結(jié)構(gòu)體類型數(shù)據(jù)作為函數(shù)參數(shù)(三種方法)
將一個結(jié)構(gòu)體中變量中的數(shù)據(jù)傳遞給另一個函數(shù),有以下三種方法。需要的朋友可以過來參考下,希望對大家有所幫助2013-10-10