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ù),給通訊錄進行初始化操作。用menmove實現(xiàn)通訊錄的刪除功能。
增加功能設(shè)計時,需要考慮特殊情況,如果通訊錄滿了就不能再添加啦。刪除功能設(shè)計時也要考慮特殊情況,如果通訊錄為空(sz為0),則就不能刪除了。這里的排序功能用的是冒泡排序?qū)崿F(xiàn)。
整體的編寫風(fēng)格采用的是分文件編寫的方式:Contact.h文件,負責(zé)函數(shù)、結(jié)構(gòu)體聲明、define常量的定義、枚舉的定義、頭文件的包含。Contact.c文件,負責(zé)通訊錄各個功能函數(shù)體的實現(xiàn)。test.c文件,負責(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)版通訊錄的代碼分享的詳細內(nèi)容,更多關(guān)于C語言靜態(tài)通訊錄的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
C語言 function recursion函數(shù)遞歸詳解
遞歸指的是在函數(shù)的定義中使用函數(shù)自身的方法,舉個例子: 從前有座山,山里有座廟,廟里有個老和尚,正在給小和尚講故事呢!故事是什么呢?"從前有座山,山里有座廟,廟里有個老和尚,正在給小和尚講故事呢!故事是什么呢?"從前有座山,山里有座廟,循環(huán)下去2021-10-10
C++讀取NC數(shù)據(jù)的結(jié)果與真實數(shù)值不一致的解決方法
本文介紹基于C++ 語言的netCDF庫讀取.nc格式的柵格文件時,代碼讀取到的數(shù)據(jù)與柵格文件的實際數(shù)據(jù)不一致的解決方法,文中通過代碼示例和圖文講解的非常詳細,需要的朋友可以參考下2024-03-03
Cocos2d-x 3.x入門教程(一):基礎(chǔ)概念
這篇文章主要介紹了Cocos2d-x 3.x入門教程(一):基礎(chǔ)概念,本文講解了Director、Scene、Layer、Sprite等內(nèi)容,需要的朋友可以參考下2014-11-11
C++實現(xiàn)LeetCode(68.文本左右對齊)
這篇文章主要介紹了C++實現(xiàn)LeetCode(68.文本左右對齊),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07
C++可變參數(shù)函數(shù)的實現(xiàn)方法示例
這篇文章主要給大家介紹了關(guān)于C++可變參數(shù)函數(shù)的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
詳解C++如何實現(xiàn)在Word文檔中創(chuàng)建列表
這篇文章主要為大家詳細介紹了介紹如何使用C++在Word文檔中創(chuàng)建編號列表、項目符號列表和多級列表,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-05-05

