目錄
創(chuàng)新互聯(lián)建站是專(zhuān)業(yè)的阿拉善盟網(wǎng)站建設(shè)公司,阿拉善盟接單;提供網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè),網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專(zhuān)業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行阿拉善盟網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專(zhuān)業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專(zhuān)業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!一.模塊設(shè)計(jì)
二.text.c
1.開(kāi)始菜單
2.main()函數(shù)的設(shè)計(jì)
三.contact.h與contact.c里主要函數(shù)的實(shí)現(xiàn)
1.添加聯(lián)系人AddContact
2.刪除聯(lián)系人DelContact
3.查找聯(lián)系人SearchContact
4.修改聯(lián)系人ModifyContact
5.顯示所有聯(lián)系人ShowContact
6.排序聯(lián)系人SortByName
四.源碼及運(yùn)行實(shí)況
1.text.c
2.contact.c
3.contact.h
采用多文件的形式:
二.text.c 1.開(kāi)始菜單1.test.c? ? ? ? ? //測(cè)試通訊錄,包含main(),menu()
2.contact.h? ? ? ?//包含頭文件及實(shí)現(xiàn)通訊錄所需函數(shù)的聲明
3.contact.c? ? ? ?//實(shí)現(xiàn)通訊錄所需函數(shù)的實(shí)現(xiàn)
我們首先設(shè)計(jì)“menu()”函數(shù)來(lái)模擬實(shí)現(xiàn)對(duì)通訊錄最初的選擇
menu()具有以下功能:
1.add? ? ? ?//添加聯(lián)系人
2.del? ? ? ? //刪除聯(lián)系人
3.search? //查找聯(lián)系人
4.modify? //修改聯(lián)系人
5.show? ? //顯示所有聯(lián)系人
6.sort? ? ? //排序聯(lián)系人
0.exit? ? ? //退出
并且為了不只選擇一次就結(jié)束,應(yīng)將menu()函數(shù)放到循環(huán)里,當(dāng)客戶(hù)輸入0.exit時(shí)程序才結(jié)束。?
具體代碼如下:
void menu()
{
printf("************************************\n");
printf("****** 1. add 2. del ******\n");
printf("****** 3. search 4. modify ******\n");
printf("****** 5. show 6. sort ******\n");
printf("****** 0. exit ******\n");
printf("************************************\n");
}
int input = 0;
do
{
menu();
printf("請(qǐng)選擇:>");
scanf("%d", &input);
switch(input)
{
case 1:
break;
case 2:
break;
case 3:
break;
case 4:
break;
case 5:
break;
case 6:;
break;
case 7:
break;
case 0:
printf("退出通訊錄\n");
break;
default:
printf("選擇錯(cuò)誤,請(qǐng)重新選擇\n");
break;
}while(input);
2.main()函數(shù)的設(shè)計(jì)要實(shí)現(xiàn)一個(gè)通訊錄,需要用到一個(gè)人的姓名、性別、地址等信息,我們將這些信息封裝在結(jié)構(gòu)體中,因此增刪查改某個(gè)人的信息也就是增刪查改一個(gè)結(jié)構(gòu)體的信息,我們用函數(shù)分別實(shí)現(xiàn)這些功能
//人的信息
typedef struct PeoInfo
{
char name[NAME_MAX];
int age;
char sex[SEX_MAX];
char addr[ADDR_MAX];
char tele[TELE_MAX];
}PeoInfo;
typedef struct Contact
{
PeoInfo data[MAX];//存放人的信息的
int sz; //當(dāng)前已經(jīng)放的信息的個(gè)數(shù)
}Contact;
在沒(méi)有添加任何人的信息之前,通訊錄結(jié)構(gòu)體里信息量理應(yīng)為0,因此我們應(yīng)初始化以下;
void InitContact(Contact* pc)
{
assert(pc);
pc->sz = 0;
memset(pc->data, 0, sizeof(pc->data));
}
所以main( )函數(shù)如下:?
int main()
{
int input = 0;
Contact con;
InitContact(&con);
do
{
menu();
printf("請(qǐng)選擇:>");
scanf("%d", &input);
switch (input)
{
case 1:
AddContact(&con);
break;
case 2:
DelContact(&con);
break;
case 3:
SearchContact(&con);
break;
case 4:
ModifyContact(&con);
break;
case 5:
ShowContact(&con);
break;
case 6:
qsort(&con, con.sz, sizeof(con.data[0]), cmp);
break;
case 0:
printf("退出通訊錄\n");
break;
default:
printf("選擇錯(cuò)誤,請(qǐng)重新選擇\n");
break;
}
} while (input);
return 0;
}
三.contact.h與contact.c里主要函數(shù)的實(shí)現(xiàn)
1.添加聯(lián)系人AddContact注:如果通訊錄滿(mǎn)了,就無(wú)法添加新成員,故需特判一下。
void AddContact(Contact* pc)
{
assert(pc);
if (pc->sz == MAX)
{
printf("通訊錄已滿(mǎn),無(wú)法添加\n");
return;
}
//增加一個(gè)人的信息
printf("請(qǐng)輸入名字:>");
scanf("%s", pc->data[pc->sz].name);
printf("請(qǐng)輸入年齡:>");
scanf("%d", &(pc->data[pc->sz].age));
printf("請(qǐng)輸入性別:>");
scanf("%s", pc->data[pc->sz].sex);
printf("請(qǐng)輸入地址:>");
scanf("%s", pc->data[pc->sz].addr);
printf("請(qǐng)輸入電話:>");
scanf("%s", pc->data[pc->sz].tele);
pc->sz++;
}
void AddContact(Contact* pc)?;函數(shù)聲明放到contact.h里
2.刪除聯(lián)系人DelContact我們需要先查找指定的聯(lián)系人,再刪除,這和后面的實(shí)現(xiàn)查找聯(lián)系人函數(shù)和實(shí)現(xiàn)修改聯(lián)系人函數(shù)有重疊的代碼塊,都是先查找到指定的聯(lián)系人,再執(zhí)行下一步操作,因此我們把查找的過(guò)程封裝為另一個(gè)函數(shù)FindByName,遇到查找直接調(diào)用即可:
int FindByName(const Contact* pc, char name[])
{
assert(pc);
int i = 0;
for (i = 0; i< pc->sz; i++)
{
if (strcmp(pc->data[i].name, name) == 0)
{
return i;
}
}
return -1;
}
void DelContact(Contact* pc)
{
assert(pc);
char name[NAME_MAX] = {0};
if (pc->sz == 0)
{
printf("通訊錄為空,無(wú)法刪除\n");
return;
}
//刪除
//找到要?jiǎng)h除的人
printf("請(qǐng)輸入要?jiǎng)h除的人的名字:>");
scanf("%s", name);
int ret = FindByName(pc, name);
if (-1 == ret)
{
printf("要?jiǎng)h除的人不存在\n");
return;
}
int i = 0;
//刪除
for (i = ret; i< pc->sz-1; i++)
{
pc->data[i] = pc->data[i + 1];
}
pc->sz--;
printf("刪除成功\n");
}
void DelContact(Contact* pc) ;函數(shù)聲明放到contact.h里
3.查找聯(lián)系人SearchContactvoid SearchContact(const Contact* pc)
{
assert(pc);
char name[NAME_MAX] = {0};
printf("請(qǐng)輸入要查找人的名字:>");
scanf("%s", name);
int pos = FindByName(pc, name);
if (-1 == pos)
{
printf("要查找的人不存在\n");
return;
}
//打印信息
printf("%-20s\t%-4s\t%-5s\t%-20s\t%-12s\n", "名字", "年齡", "性別", "地址", "電話");
printf("%-20s\t%-4d\t%-5s\t%-20s\t%-12s\n", pc->data[pos].name,
pc->data[pos].age,
pc->data[pos].sex,
pc->data[pos].addr,
pc->data[pos].tele);
}
4.修改聯(lián)系人ModifyContactvoid ModifyContact(Contact* pc)
{
assert(pc);
char name[NAME_MAX] = { 0 };
printf("請(qǐng)輸入要修改人的名字:>");
scanf("%s", name);
int pos = FindByName(pc, name);
if (-1 == pos)
{
printf("要修改的人不存在\n");
return;
}
printf("請(qǐng)輸入名字:>");
scanf("%s", pc->data[pos].name);
printf("請(qǐng)輸入年齡:>");
scanf("%d", &(pc->data[pos].age));
printf("請(qǐng)輸入性別:>");
scanf("%s", pc->data[pos].sex);
printf("請(qǐng)輸入地址:>");
scanf("%s", pc->data[pos].addr);
printf("請(qǐng)輸入電話:>");
scanf("%s", pc->data[pos].tele);
printf("修改完成\n");
}
5.顯示所有聯(lián)系人ShowContactvoid ShowContact(const Contact* pc)
{
assert(pc);
int i = 0;
printf("%-20s\t%-4s\t%-5s\t%-20s\t%-12s\n", "名字", "年齡", "性別", "地址", "電話");
for (i = 0; i< pc->sz; i++)
{
printf("%-20s\t%-4d\t%-5s\t%-20s\t%-12s\n", pc->data[i].name,
pc->data[i].age,
pc->data[i].sex,
pc->data[i].addr,
pc->data[i].tele);
}
}
6.排序聯(lián)系人SortByName按名字排序,也就是按字符串排序,使用qsort()函數(shù)實(shí)現(xiàn)
//qsort
int cmp(const void* s1, const void* s2)
{
assert(s1 && s2);
return strcmp((char*)s1, (char*)s2);
}
四.源碼及運(yùn)行實(shí)況
1.text.c#define _CRT_SECURE_NO_WARNINGS 1
#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("****** 0. exit ******\n");
printf("************************************\n");
}
int main()
{
int input = 0;
Contact con;
InitContact(&con);
do
{
menu();
printf("請(qǐng)選擇:>");
scanf("%d", &input);
switch (input)
{
case 1:
AddContact(&con);
break;
case 2:
DelContact(&con);
break;
case 3:
SearchContact(&con);
break;
case 4:
ModifyContact(&con);
break;
case 5:
ShowContact(&con);
break;
case 6:
qsort(&con, con.sz, sizeof(con.data[0]), cmp);
break;
case 0:
printf("退出通訊錄\n");
break;
default:
printf("選擇錯(cuò)誤,請(qǐng)重新選擇\n");
break;
}
} while (input);
return 0;
}
2.contact.c#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"
void InitContact(Contact* pc)
{
assert(pc);
pc->sz = 0;
memset(pc->data, 0, sizeof(pc->data));
}
void AddContact(Contact* pc)
{
assert(pc);
if (pc->sz == MAX)
{
printf("通訊錄已滿(mǎn),無(wú)法添加\n");
return;
}
//增加一個(gè)人的信息
printf("請(qǐng)輸入名字:>");
scanf("%s", pc->data[pc->sz].name);
printf("請(qǐng)輸入年齡:>");
scanf("%d", &(pc->data[pc->sz].age));
printf("請(qǐng)輸入性別:>");
scanf("%s", pc->data[pc->sz].sex);
printf("請(qǐng)輸入地址:>");
scanf("%s", pc->data[pc->sz].addr);
printf("請(qǐng)輸入電話:>");
scanf("%s", pc->data[pc->sz].tele);
pc->sz++;
}
void ShowContact(const Contact* pc)
{
assert(pc);
int i = 0;
printf("%-20s\t%-4s\t%-5s\t%-20s\t%-12s\n", "名字", "年齡", "性別", "地址", "電話");
for (i = 0; i< pc->sz; i++)
{
printf("%-20s\t%-4d\t%-5s\t%-20s\t%-12s\n", pc->data[i].name,
pc->data[i].age,
pc->data[i].sex,
pc->data[i].addr,
pc->data[i].tele);
}
}
int FindByName(const Contact* pc, char name[])
{
assert(pc);
int i = 0;
for (i = 0; i< pc->sz; i++)
{
if (strcmp(pc->data[i].name, name) == 0)
{
return i;
}
}
return -1;
}
void DelContact(Contact* pc)
{
assert(pc);
char name[NAME_MAX] = { 0 };
if (pc->sz == 0)
{
printf("通訊錄為空,無(wú)法刪除\n");
return;
}
//刪除
//找到要?jiǎng)h除的人
printf("請(qǐng)輸入要?jiǎng)h除的人的名字:>");
scanf("%s", name);
int ret = FindByName(pc, name);
if (-1 == ret)
{
printf("要?jiǎng)h除的人不存在\n");
return;
}
int i = 0;
//刪除
for (i = ret; i< pc->sz - 1; i++)
{
pc->data[i] = pc->data[i + 1];
}
pc->sz--;
printf("刪除成功\n");
}
void SearchContact(const Contact* pc)
{
assert(pc);
char name[NAME_MAX] = { 0 };
printf("請(qǐng)輸入要查找人的名字:>");
scanf("%s", name);
int pos = FindByName(pc, name);
if (-1 == pos)
{
printf("要查找的人不存在\n");
return;
}
//打印信息
printf("%-20s\t%-4s\t%-5s\t%-20s\t%-12s\n", "名字", "年齡", "性別", "地址", "電話");
printf("%-20s\t%-4d\t%-5s\t%-20s\t%-12s\n", pc->data[pos].name,
pc->data[pos].age,
pc->data[pos].sex,
pc->data[pos].addr,
pc->data[pos].tele);
}
void ModifyContact(Contact* pc)
{
assert(pc);
char name[NAME_MAX] = { 0 };
printf("請(qǐng)輸入要修改人的名字:>");
scanf("%s", name);
int pos = FindByName(pc, name);
if (-1 == pos)
{
printf("要修改的人不存在\n");
return;
}
printf("請(qǐng)輸入名字:>");
scanf("%s", pc->data[pos].name);
printf("請(qǐng)輸入年齡:>");
scanf("%d", &(pc->data[pos].age));
printf("請(qǐng)輸入性別:>");
scanf("%s", pc->data[pos].sex);
printf("請(qǐng)輸入地址:>");
scanf("%s", pc->data[pos].addr);
printf("請(qǐng)輸入電話:>");
scanf("%s", pc->data[pos].tele);
printf("修改完成\n");
}
//qsort
int cmp(const void* s1, const void* s2)
{
assert(s1 && s2);
return strcmp((char*)s1, (char*)s2);
}
3.contact.h#pragma once
#include#include#include
#define MAX 100
#define NAME_MAX 20
#define SEX_MAX 5
#define ADDR_MAX 30
#define TELE_MAX 12
//人的信息
typedef struct PeoInfo
{
char name[NAME_MAX];
int age;
char sex[SEX_MAX];
char addr[ADDR_MAX];
char tele[TELE_MAX];
}PeoInfo;
typedef struct Contact
{
PeoInfo data[MAX];//存放人的信息的
int sz;//當(dāng)前已經(jīng)放的信息的個(gè)數(shù)
}Contact;
//初始化通訊錄
void InitContact(Contact* pc);
//增加聯(lián)系人
void AddContact(Contact* pc);
//刪除指定聯(lián)系人
void DelContact(Contact* pc);
//顯示通訊錄中的信息
void ShowContact(const Contact* pc);
//查找指定聯(lián)系人
void SearchContact(const Contact* pc);
//修改指定聯(lián)系人
void ModifyContact(Contact* pc);
//按名字排序通訊錄
int cmp(const void* s1, const void* s2);
本篇到此結(jié)束,碼文不易,還請(qǐng)多多支持哦!
你是否還在尋找穩(wěn)定的海外服務(wù)器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機(jī)房具備T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確流量調(diào)度確保服務(wù)器高可用性,企業(yè)級(jí)服務(wù)器適合批量采購(gòu),新人活動(dòng)首月15元起,快前往官網(wǎng)查看詳情吧
新聞名稱(chēng):C語(yǔ)言實(shí)現(xiàn)靜態(tài)通訊錄-創(chuàng)新互聯(lián)
標(biāo)題URL:http://muchs.cn/article22/dodocc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、網(wǎng)站收錄、網(wǎng)站營(yíng)銷(xiāo)、ChatGPT、手機(jī)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容
網(wǎng)頁(yè)設(shè)計(jì)公司知識(shí)