基于C語言實(shí)現(xiàn)靜態(tài)通訊錄的示例代碼
一、項(xiàng)目要求
實(shí)現(xiàn)一個(gè)通訊錄
通訊錄可以用來存儲100個(gè)人的信息,每個(gè)人的信息包括:姓名、性別、年齡、電話、住址
提供方法:
- 添加聯(lián)系人信息
- 刪除指定聯(lián)系人信息
- 查找指定聯(lián)系人信息
- 修改指定聯(lián)系人信息
- 顯示所有聯(lián)系人信息
- 清空所有聯(lián)系人
- 以名字排序所有聯(lián)系人
二、Contact.h
#pragma once #define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <assert.h> #include <string.h> #include <stdlib.h> #define MAX_NAME 20 #define MAX_SEX 10 #define MAX_TELE 12 #define MAX_ADDR 30 #define MAX_CAPACITY 100 typedef struct PeoInfo { char name[MAX_NAME]; char sex[MAX_SEX]; char tele[MAX_TELE]; char addr[MAX_ADDR]; int age; }PeoInfo; typedef struct Contact { PeoInfo date[MAX_CAPACITY]; int size; }Contact; void ContactInit(Contact* pc);//初始化通訊錄 void ContactPrint(const Contact* pc);//打印 void ContactAdd(Contact* pc);//增加聯(lián)系人信息 void ContactDel(Contact* pc);//刪除聯(lián)系人信息 void ContactFind(const Contact* pc);//查找信息 void ContactModify(Contact* pc);//修改信息 void ContactSortByName(Contact* pc);//排序 void ContactEmpty(Contact* pc);//清空通訊錄
先定義一個(gè)PeoInfo的結(jié)構(gòu)體類型,里面包含了人的信息。
再將PeoInfo的數(shù)組和數(shù)組有效元素個(gè)數(shù)size包含至Contact,作為通訊錄的模板。
三、Contact.c
1、靜態(tài)函數(shù)
static int FindByName(const Contact* pc,const char arr[])//通過名字查找 { assert(pc&&arr); for (int i = 0; i < pc->size; i++) { if (strcmp(pc->date[i].name, arr) == 0) { return i; } } return -1; }
可以通過名字查找通訊錄中是否存在聯(lián)系人,存在返回下標(biāo),不存在返回-1
2、初始化通訊錄
void ContactInit(Contact* pc)//初始化通訊錄 { assert(pc); pc->size = 0; memset(pc->date, 0, sizeof(pc->date)); }
將size置為0,使用memset函數(shù)將pc->date的內(nèi)存按字節(jié)全部置為0
3、打印
void ContactPrint(const Contact* pc)//打印 { assert(pc); printf("姓名\t性別\t電話\t地址\t年齡\n"); for (int i = 0; i < pc->size; i++) { printf("%s\t%s\t%s\t%s\t%d\n", pc->date[i].name, pc->date[i].sex, pc->date[i].tele, pc->date[i].addr, pc->date[i].age); } }
for循環(huán)遍歷打印pc->date中的結(jié)構(gòu)體成員
4、增加聯(lián)系人信息
void ContactAdd(Contact* pc)//增加聯(lián)系人信息 { assert(pc&&pc->size<= MAX_CAPACITY); printf("請輸入姓名:\n"); scanf("%s", pc->date[pc->size].name); printf("請輸入性別:\n"); scanf("%s", pc->date[pc->size].sex); printf("請輸入電話:\n"); scanf("%s", pc->date[pc->size].tele); printf("請輸入地址:\n"); scanf("%s", pc->date[pc->size].addr); printf("請輸入年齡:\n"); scanf("%d", &(pc->date[pc->size].age)); pc->size++; }
注意增加聯(lián)系人后pc->size++
5、通過名字查找
void ContactFind(const Contact* pc)//查找信息 { assert(pc); printf("請輸入姓名查找:"); char arr[20] = { 0 }; scanf("%s", arr); int pos = FindByName(pc, arr); if (pos != -1) { printf("查找到如下信息:\n"); printf("姓名\t性別\t電話\t地址\t年齡\n"); printf("%s\t%s\t%s\t%s\t%d\n", pc->date[pos].name, pc->date[pos].sex, pc->date[pos].tele, pc->date[pos].addr, pc->date[pos].age); } else printf("通訊錄查無此人!\n"); }
先判斷查找的信息是否在通訊錄中,再打印該下標(biāo)的信息。
6、刪除聯(lián)系人信息
void ContactDel(Contact* pc)//刪除聯(lián)系人信息 { assert(pc); printf("請輸入姓名查找:"); char arr[20]={0}; scanf("%s", arr); int pos = FindByName(pc, arr);//記錄size的位置 if (pos==-1) { printf("通訊錄沒有該信息\n"); return; } for (int i = pos; i < pc->size - 1; i++)//移動元素 { pc->date[i] = pc->date[i + 1]; } pc->size--; printf("刪除成功!\n"); }
通過靜態(tài)函數(shù)FindByName返回的下標(biāo),通過for循環(huán)將后續(xù)元素逐個(gè)進(jìn)行覆蓋。
7、修改信息
void ContactModify(Contact* pc)//修改信息 { assert(pc); printf("請輸入姓名查找:"); char arr[20] = { 0 }; scanf("%s", arr); int pos = FindByName(pc, arr); if (pos == -1) { printf("找不到\n"); return; } else { printf("請輸入更改后的姓名:\n"); scanf("%s", pc->date[pos].name); printf("請輸入更改后的性別:\n"); scanf("%s", pc->date[pos].sex); printf("請輸入更改后的電話:\n"); scanf("%s", pc->date[pos].tele); printf("請輸入更改后的地址:\n"); scanf("%s", pc->date[pos].addr); printf("請輸入更改后的年齡:\n"); scanf("%d", &(pc->date[pos].age)); } }
先判斷查找的信息是否在通訊錄中,再打印該下標(biāo)的信息。
8、排序通訊錄
int name_cmp(const void* e1, const void* e2) { return strcmp(((PeoInfo*)e1)->name,((PeoInfo*)e2)->name); } void ContactSortByName(Contact* pc)//排序 { assert(pc&&pc->size!=0); qsort(pc->date, pc->size, sizeof(PeoInfo), name_cmp); printf("排序完成\n"); }
使用qsort函數(shù)排序通訊錄,可參照本文學(xué)習(xí)qsort排序結(jié)構(gòu)體的方法
9、清空通訊錄
void ContactEmpty(Contact* pc)//清空通訊錄 { assert(pc); ContactInit(pc); printf("通訊錄已清空\n"); }
本文為靜態(tài)通訊錄,非動態(tài)開辟內(nèi)存,此處使用初始化函數(shù)即可。
四、text.c
#include "contact.h" void menu() { printf("###########################\n"); printf("#####1、add 2、del######\n"); printf("#####3、find 4、modify###\n"); printf("#####5、print 6、sort#####\n"); printf("#####7、empty 8、exit#####\n"); printf("###########################\n"); } enum option { ADD=1, DEL, FIND, MODIFY, PRINT, SORT, EMPTY, EXIT }; int main() { int input = 0; Contact c;//創(chuàng)建一個(gè)通訊錄 ContactInit(&c);//初始化通訊錄 while (1) { menu(); printf("請輸入選項(xiàng):\n"); scanf("%d", &input); if (input == ADD) ContactAdd(&c);//增加聯(lián)系人信息 else if (input == DEL) ContactDel(&c);//刪除聯(lián)系人信息 else if (input == FIND) ContactFind(&c);//查找聯(lián)系人信息 else if (input == MODIFY) ContactModify(&c);//修改聯(lián)系人信息 else if (input == PRINT) ContactPrint(&c);//打印 else if (input == SORT) ContactSortByName(&c);//排序 else if (input == EMPTY) ContactEmpty(&c);//清空通訊錄 else if (input == EXIT) break;//退出 else printf("輸入錯誤!請重新輸入!\n"); } return 0; }
使用enum枚舉選項(xiàng)。
五、動圖展示
以上就是基于C語言實(shí)現(xiàn)靜態(tài)通訊錄的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于C語言靜態(tài)通訊錄的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Windows網(wǎng)絡(luò)編程之winsock實(shí)現(xiàn)文件傳輸示例
這篇文章主要介紹了Windows網(wǎng)絡(luò)編程之winsock實(shí)現(xiàn)文件傳輸示例,對于學(xué)習(xí)Windows網(wǎng)絡(luò)程序設(shè)計(jì)來說具有很好的學(xué)習(xí)借鑒價(jià)值,需要的朋友可以參考下2014-08-08C語言實(shí)現(xiàn)個(gè)人通訊錄管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)個(gè)人通訊錄管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12C語言中操作utmp文件的相關(guān)函數(shù)用法
這篇文章主要介紹了C語言中操作utmp文件的相關(guān)函數(shù)用法,包括getutent()函數(shù)和setutent()函數(shù)以及endutent()函數(shù),需要的朋友可以參考下2015-08-08C語言中實(shí)現(xiàn)“17進(jìn)制”轉(zhuǎn)“10進(jìn)制”實(shí)例代碼
這篇文章主要介紹了C語言中實(shí)現(xiàn)“17進(jìn)制”轉(zhuǎn)“10進(jìn)制”實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-05-05C++ 實(shí)現(xiàn)稀疏矩陣的壓縮存儲的實(shí)例
這篇文章主要介紹了C++ 實(shí)現(xiàn)稀疏矩陣的壓縮存儲的實(shí)例的相關(guān)資料,M*N的矩陣,矩陣中有效值的個(gè)數(shù)遠(yuǎn)小于無效值的個(gè)數(shù),且這些數(shù)據(jù)的分布沒有規(guī)律,需要的朋友可以參考下2017-07-07C++ BloomFilter布隆過濾器應(yīng)用及概念詳解
布隆過濾器是由布?。˙urton Howard Bloom)在1970年提出的 一種緊湊型的、比較巧妙的概率型數(shù)據(jù)結(jié)構(gòu),特點(diǎn)是高效地插入和查詢,可以用來告訴你 “某樣?xùn)|西一定不存在或者可能存在”,它是用多個(gè)哈希函數(shù),將一個(gè)數(shù)據(jù)映射到位圖結(jié)構(gòu)中2023-03-03C語言 數(shù)據(jù)結(jié)構(gòu)堆排序順序存儲(升序)
這篇文章主要介紹了C語言 數(shù)據(jù)結(jié)構(gòu)堆排序順序存儲(升序)的相關(guān)資料,需要的朋友可以參考下2017-05-05