目錄
創(chuàng)新互聯(lián)建站是專業(yè)的阿拉善盟網(wǎng)站建設公司,阿拉善盟接單;提供網(wǎng)站設計、網(wǎng)站建設,網(wǎng)頁設計,網(wǎng)站設計,建網(wǎng)站,PHP網(wǎng)站建設等專業(yè)做網(wǎng)站服務;采用PHP框架,可快速的進行阿拉善盟網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!一.模塊設計
二.text.c
1.開始菜單
2.main()函數(shù)的設計
三.contact.h與contact.c里主要函數(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
四.源碼及運行實況
1.text.c
2.contact.c
3.contact.h
采用多文件的形式:
二.text.c 1.開始菜單1.test.c? ? ? ? ? //測試通訊錄,包含main(),menu()
2.contact.h? ? ? ?//包含頭文件及實現(xiàn)通訊錄所需函數(shù)的聲明
3.contact.c? ? ? ?//實現(xiàn)通訊錄所需函數(shù)的實現(xiàn)
我們首先設計“menu()”函數(shù)來模擬實現(xiàn)對通訊錄最初的選擇
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? ? ? //退出
并且為了不只選擇一次就結束,應將menu()函數(shù)放到循環(huán)里,當客戶輸入0.exit時程序才結束。?
具體代碼如下:
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("請選擇:>");
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("選擇錯誤,請重新選擇\n");
break;
}while(input);
2.main()函數(shù)的設計要實現(xiàn)一個通訊錄,需要用到一個人的姓名、性別、地址等信息,我們將這些信息封裝在結構體中,因此增刪查改某個人的信息也就是增刪查改一個結構體的信息,我們用函數(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; //當前已經(jīng)放的信息的個數(shù)
}Contact;
在沒有添加任何人的信息之前,通訊錄結構體里信息量理應為0,因此我們應初始化以下;
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("請選擇:>");
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("選擇錯誤,請重新選擇\n");
break;
}
} while (input);
return 0;
}
三.contact.h與contact.c里主要函數(shù)的實現(xiàn)
1.添加聯(lián)系人AddContact注:如果通訊錄滿了,就無法添加新成員,故需特判一下。
void AddContact(Contact* pc)
{
assert(pc);
if (pc->sz == MAX)
{
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].addr);
printf("請輸入電話:>");
scanf("%s", pc->data[pc->sz].tele);
pc->sz++;
}
void AddContact(Contact* pc)?;函數(shù)聲明放到contact.h里
2.刪除聯(lián)系人DelContact我們需要先查找指定的聯(lián)系人,再刪除,這和后面的實現(xiàn)查找聯(lián)系人函數(shù)和實現(xiàn)修改聯(lián)系人函數(shù)有重疊的代碼塊,都是先查找到指定的聯(lián)系人,再執(zhí)行下一步操作,因此我們把查找的過程封裝為另一個函數(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("通訊錄為空,無法刪除\n");
return;
}
//刪除
//找到要刪除的人
printf("請輸入要刪除的人的名字:>");
scanf("%s", name);
int ret = FindByName(pc, name);
if (-1 == ret)
{
printf("要刪除的人不存在\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("請輸入要查找人的名字:>");
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("請輸入要修改人的名字:>");
scanf("%s", name);
int pos = FindByName(pc, name);
if (-1 == pos)
{
printf("要修改的人不存在\n");
return;
}
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].addr);
printf("請輸入電話:>");
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ù)實現(xiàn)
//qsort
int cmp(const void* s1, const void* s2)
{
assert(s1 && s2);
return strcmp((char*)s1, (char*)s2);
}
四.源碼及運行實況
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("請選擇:>");
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("選擇錯誤,請重新選擇\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("通訊錄已滿,無法添加\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].addr);
printf("請輸入電話:>");
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("通訊錄為空,無法刪除\n");
return;
}
//刪除
//找到要刪除的人
printf("請輸入要刪除的人的名字:>");
scanf("%s", name);
int ret = FindByName(pc, name);
if (-1 == ret)
{
printf("要刪除的人不存在\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("請輸入要查找人的名字:>");
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("請輸入要修改人的名字:>");
scanf("%s", name);
int pos = FindByName(pc, name);
if (-1 == pos)
{
printf("要修改的人不存在\n");
return;
}
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].addr);
printf("請輸入電話:>");
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;//當前已經(jīng)放的信息的個數(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);
本篇到此結束,碼文不易,還請多多支持哦!
你是否還在尋找穩(wěn)定的海外服務器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機房具備T級流量清洗系統(tǒng)配攻擊溯源,準確流量調(diào)度確保服務器高可用性,企業(yè)級服務器適合批量采購,新人活動首月15元起,快前往官網(wǎng)查看詳情吧