C語言實現(xiàn)靜態(tài)版通訊錄的代碼分享
前言
哈嘍各位友友們,我今天又學(xué)到了很多有趣的知識,現(xiàn)在迫不及待的想和大家分享一下!我僅已此文,手把手帶領(lǐng)大家在學(xué)習(xí)C語言知識的同時,并實現(xiàn)一個靜態(tài)版的通訊錄!主要運用了結(jié)構(gòu)體,一維數(shù)組,函數(shù),分支與循環(huán)語句等等知識,以及分文件書寫項目思想。都是精華內(nèi)容,可不要錯過喲?。?!
通訊錄設(shè)計的關(guān)鍵思想點分析
首先根據(jù)我們通訊錄的業(yè)務(wù)需求設(shè)計好我們的個人信息結(jié)構(gòu)體(PeoInfor)。這里設(shè)計的每一個人的信息包括:姓名,年齡,性別,電話,地址。然后就可以設(shè)計出我們具體的結(jié)構(gòu)體啦!
為了方便后面代碼的設(shè)計傳參,這里再設(shè)計一個結(jié)構(gòu)體(Contact),包括能夠存放1000個通訊信息的空間和sz記錄通訊錄中信息的條數(shù)。
先設(shè)計好通訊錄需要完成什么功能,這里是設(shè)計出增加信息、刪除信息、查詢信息、修改信息、按年齡排序信息、顯示信息、退出通訊錄這幾大功能。
這里使用到了memset,memmove內(nèi)存函數(shù),大家可以先去查找學(xué)習(xí)一下。這里利用menmset函數(shù),給通訊錄進(jìn)行初始化操作。用menmove實現(xiàn)通訊錄的刪除功能。
增加功能設(shè)計時,需要考慮特殊情況,如果通訊錄滿了就不能再添加啦。刪除功能設(shè)計時也要考慮特殊情況,如果通訊錄為空(sz為0),則就不能刪除了。這里的排序功能用的是冒泡排序?qū)崿F(xiàn)。
整體的編寫風(fēng)格采用的是分文件編寫的方式:Contact.h文件,負(fù)責(zé)函數(shù)、結(jié)構(gòu)體聲明、define常量的定義、枚舉的定義、頭文件的包含。Contact.c文件,負(fù)責(zé)通訊錄各個功能函數(shù)體的實現(xiàn)。test.c文件,負(fù)責(zé)測試通訊錄的功能。
通訊錄界面(meun)設(shè)計
通訊錄菜單界面(meun)設(shè)計的代碼編寫:
void meun() { printf("**************************************\n"); printf("****** 1.Add 2.Del *******\n"); printf("****** 3.Search 4.Modify *******\n"); printf("****** 5.Sort 6.Print *******\n"); printf("****** 0.Exit *******\n"); printf("**************************************\n"); }
界面成果圖展示:
增加信息功能實現(xiàn)代碼
//增加通訊錄信息 void AddContact(Contact* pc) { if (DATA_MAX == pc->sz) { printf("通訊錄信息存儲空間已滿!\n"); return; } printf("請輸入名字:> "); scanf("%s", pc->data[pc->sz].name); printf("請輸入年齡:> "); scanf("%d", &(pc->data[pc->sz].age)); printf("請輸入性別:> "); scanf("%s", pc->data[pc->sz].sex); printf("請輸入電話:> "); scanf("%s", pc->data[pc->sz].tele); printf("請輸入住址:> "); scanf("%s", pc->data[pc->sz].addr); printf("信息添加成功!\n"); pc->sz++; }
刪除信息功能實現(xiàn)代碼
void DelContact(Contact* pc) { char name[NAME_MAX]; printf("請輸入要刪除的人的名字:> "); scanf("%s", name); if (pc->sz == 0) { printf("通訊錄已空!\n"); return; } int pos = FindByName(pc, name); if (pos == -1) { printf("通訊錄中無此要刪除的人的信息\n"); return; } memmove(pc->data + pos, pc->data + pos + 1, (pc->sz - 1 - pos) * sizeof(pc->data[0])); pc->sz--; printf("刪除成功!\n"); }
查詢信息功能實現(xiàn)代碼
//查詢通訊錄信息 void SearchContact(Contact* pc) { char name[NAME_MAX]; printf("請輸入要查詢的人的名字:> "); scanf("%s", name); int pos = FindByName(pc, name); if (pos == -1) { printf("通訊錄中無此查詢?nèi)说男畔n"); return 0; } printf("%-20s %-10s %-15s %-30s %-30s\n", "姓名", "年齡", "性別", "電話", "地址"); printf("%-20s %-10d %-15s %-30s %-30s\n", pc->data[pos].name, pc->data[pos].age, pc->data[pos].sex, pc->data[pos].tele, pc->data[pos].addr); }
修改信息功能實現(xiàn)代碼
//修改通訊錄信息 void ModifyContact(Contact* pc) { char name[NAME_MAX]; printf("請輸入要修改的人的名字:> "); scanf("%s", name); int pos = FindByName(pc, name); if (pos == -1) { printf("通訊錄中無此人的信息\n"); return 0; } printf("請輸入名字:> "); scanf("%s", pc->data[pos].name); printf("請輸入年齡:> "); scanf("%d", &(pc->data[pos].age)); printf("請輸入性別:> "); scanf("%s", pc->data[pos].sex); printf("請輸入電話:> "); scanf("%s", pc->data[pos].tele); printf("請輸入住址:> "); scanf("%s", pc->data[pos].addr); ??????? printf("信息修改成功!\n"); }
按年齡升序排序信息功能實現(xiàn)代碼
//年齡排序 void SortContact(Contact* pc) { for (int i = 0; i < pc->sz; i++) { for (int j = 0; j < pc->sz - 1 - i; j++) { if (pc->data[j].age > pc->data[j + 1].age) { PeoInfor tmp = pc->data[j]; pc->data[j] = pc->data[j + 1]; pc->data[j + 1] = tmp; } } } printf("排序成功!\n"); }
顯示信息功能實現(xiàn)代碼
//打印通訊錄信息 void PrintContact(Contact* pc) { assert(pc); printf("%-20s %-10s %-15s %-30s %-30s\n","姓名","年齡","性別","電話","地址"); for (int i = 0; i < pc->sz; i++) { printf("%-20s %-10d %-15s %-30s %-30s\n", pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr); } }
通訊錄完整代碼
通訊錄頭文件代碼編寫:
#pragma once #include<stdio.h> #include<assert.h> #include<string.h> #define NAME_MAX 20 #define SEX_MAX 3 #define TELE_MAX 20 #define ADDR_MAX 30 #define DATA_MAX 1000 enum { EXIT, ADD, DEL, SEARCH, MODIFY, SORT, PRINT }; typedef struct PeoInfor { char name[NAME_MAX]; int age; char sex[SEX_MAX]; char tele[TELE_MAX]; char addr[ADDR_MAX]; }PeoInfor; typedef struct Contact { PeoInfor data[DATA_MAX]; int sz; }Contact; //初始化通訊錄 void InitContact(Contact* pc); //增加通訊錄信息 void AddContact(Contact* pc); //刪除通訊錄信息 void DelContact(Contact* pc); //查詢通訊錄信息 void SearchContact(Contact* pc); //修改通訊錄信息 void ModifyContact(Contact* pc); //排序 void SortContact(Contact* pc); //打印通訊錄信息 void PrintContact(Contact* pc);
通訊錄功能文件代碼編寫:
#define _CRT_SECURE_NO_WARNINGS 1 #include"Contact.h" //初始化通訊錄 void InitContact(Contact* pc) { assert(pc); memset(pc->data, 0, sizeof(pc->data)); pc->sz = 0; } //增加通訊錄信息 void AddContact(Contact* pc) { if (DATA_MAX == pc->sz) { printf("通訊錄信息存儲空間已滿!\n"); return; } printf("請輸入名字:> "); scanf("%s", pc->data[pc->sz].name); printf("請輸入年齡:> "); scanf("%d", &(pc->data[pc->sz].age)); printf("請輸入性別:> "); scanf("%s", pc->data[pc->sz].sex); printf("請輸入電話:> "); scanf("%s", pc->data[pc->sz].tele); printf("請輸入住址:> "); scanf("%s", pc->data[pc->sz].addr); printf("信息添加成功!\n"); pc->sz++; } int FindByName(Contact* pc, char name[]) { for (int i = 0; i < pc->sz; i++) { if (strcmp((pc->data[i].name), name) == 0) { return i; } } return -1; } void DelContact(Contact* pc) { char name[NAME_MAX]; printf("請輸入要刪除的人的名字:> "); scanf("%s", name); if (pc->sz == 0) { printf("通訊錄已空!\n"); return; } int pos = FindByName(pc, name); if (pos == -1) { printf("通訊錄中無此要刪除的人的信息\n"); return; } memmove(pc->data + pos, pc->data + pos + 1, (pc->sz - 1 - pos) * sizeof(pc->data[0])); pc->sz--; printf("刪除成功!\n"); } //查詢通訊錄信息 void SearchContact(Contact* pc) { char name[NAME_MAX]; printf("請輸入要查詢的人的名字:> "); scanf("%s", name); int pos = FindByName(pc, name); if (pos == -1) { printf("通訊錄中無此查詢?nèi)说男畔n"); return 0; } printf("%-20s %-10s %-15s %-30s %-30s\n", "姓名", "年齡", "性別", "電話", "地址"); printf("%-20s %-10d %-15s %-30s %-30s\n", pc->data[pos].name, pc->data[pos].age, pc->data[pos].sex, pc->data[pos].tele, pc->data[pos].addr); } //修改通訊錄信息 void ModifyContact(Contact* pc) { char name[NAME_MAX]; printf("請輸入要修改的人的名字:> "); scanf("%s", name); int pos = FindByName(pc, name); if (pos == -1) { printf("通訊錄中無此人的信息\n"); return 0; } printf("請輸入名字:> "); scanf("%s", pc->data[pos].name); printf("請輸入年齡:> "); scanf("%d", &(pc->data[pos].age)); printf("請輸入性別:> "); scanf("%s", pc->data[pos].sex); printf("請輸入電話:> "); scanf("%s", pc->data[pos].tele); printf("請輸入住址:> "); scanf("%s", pc->data[pos].addr); printf("信息修改成功!\n"); } //年齡排序 void SortContact(Contact* pc) { for (int i = 0; i < pc->sz; i++) { for (int j = 0; j < pc->sz - 1 - i; j++) { if (pc->data[j].age > pc->data[j + 1].age) { PeoInfor tmp = pc->data[j]; pc->data[j] = pc->data[j + 1]; pc->data[j + 1] = tmp; } } } printf("排序成功!\n"); } //打印通訊錄信息 void PrintContact(Contact* pc) { assert(pc); printf("%-20s %-10s %-15s %-30s %-30s\n","姓名","年齡","性別","電話","地址"); for (int i = 0; i < pc->sz; i++) { printf("%-20s %-10d %-15s %-30s %-30s\n", pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr); } }
通訊錄測試文件代碼編寫:
#define _CRT_SECURE_NO_WARNINGS 1 #include"Contact.h" void meun() { printf("**************************************\n"); printf("****** 1.Add 2.Del *******\n"); printf("****** 3.Search 4.Modify *******\n"); printf("****** 5.Sort 6.Print *******\n"); printf("****** 0.Exit *******\n"); printf("**************************************\n"); } void test() { Contact p; int input = 0; InitContact(&p); do { meun(); printf("請輸入功能選項:>\n"); scanf("%d", &input); switch (input) { case EXIT: printf("已退出通訊錄!\n"); break; case ADD: AddContact(&p); break; case DEL: DelContact(&p); break; case SEARCH: SearchContact(&p); break; case MODIFY: ModifyContact(&p); break; case SORT: SortContact(&p); break; case PRINT: PrintContact(&p); break; default: printf("輸入錯誤,請重新輸入!\n"); break; } } while (input); } int main() { test(); return 0; }
測試過程展示
以上就是C語言實現(xiàn)靜態(tài)版通訊錄的代碼分享的詳細(xì)內(nèi)容,更多關(guān)于C語言靜態(tài)通訊錄的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
C語言 function recursion函數(shù)遞歸詳解
遞歸指的是在函數(shù)的定義中使用函數(shù)自身的方法,舉個例子: 從前有座山,山里有座廟,廟里有個老和尚,正在給小和尚講故事呢!故事是什么呢?"從前有座山,山里有座廟,廟里有個老和尚,正在給小和尚講故事呢!故事是什么呢?"從前有座山,山里有座廟,循環(huán)下去2021-10-10C++讀取NC數(shù)據(jù)的結(jié)果與真實數(shù)值不一致的解決方法
本文介紹基于C++ 語言的netCDF庫讀取.nc格式的柵格文件時,代碼讀取到的數(shù)據(jù)與柵格文件的實際數(shù)據(jù)不一致的解決方法,文中通過代碼示例和圖文講解的非常詳細(xì),需要的朋友可以參考下2024-03-03Cocos2d-x 3.x入門教程(一):基礎(chǔ)概念
這篇文章主要介紹了Cocos2d-x 3.x入門教程(一):基礎(chǔ)概念,本文講解了Director、Scene、Layer、Sprite等內(nèi)容,需要的朋友可以參考下2014-11-11C++實現(xiàn)LeetCode(68.文本左右對齊)
這篇文章主要介紹了C++實現(xiàn)LeetCode(68.文本左右對齊),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C++可變參數(shù)函數(shù)的實現(xiàn)方法示例
這篇文章主要給大家介紹了關(guān)于C++可變參數(shù)函數(shù)的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12詳解C++如何實現(xiàn)在Word文檔中創(chuàng)建列表
這篇文章主要為大家詳細(xì)介紹了介紹如何使用C++在Word文檔中創(chuàng)建編號列表、項目符號列表和多級列表,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-05-05