文章目录
一、需求分析
实现一个简单的通讯录管理系统我们需要具备以下几点基本功能:增加通讯录的联系人,删除通讯录的联系人,查找通讯录的联系人,修改通讯录的联系人,显示通讯录的联系人,清空通讯录,按指定内容排序通讯录,实现动态版本的通讯录,避免空间不足和空间的浪费,最后保存通讯录的信息。
一共分为test.c和contact.c两个源文件,一个contact.h的头文件
test.c:是实现基本的逻辑
contact.c:是功能函数的实现
contact.h :是函数的声明,结构体的声明和头文件的包含
二、通讯录的实现
1.实现通讯录的前期准备
(1)菜单的实现
菜单的实现很简单,只需要把内容封装成一个函数,然后打印出来。
void menu()
{
printf("*************************************\n");
printf("******** 1.add 2.dele ********\n");
printf("******** 3.search 4.modify ********\n");
printf("******** 5.show 6.empty ********\n");
printf("******** 7.sort 0.exit ********\n");
printf("*************************************\n");
}
(2)实现菜单选项的逻辑
使用do…while();来控制整个逻辑的循环,里面包含switch语句,根据我们要实现的功能来选择对应的选项,选项使用枚举,我们能更好的知道我们要选择功能对应的选项是什么,这样整个菜单的逻辑就实现了。
enum Option
{
EXIT,
ADD,
DELE,
SEARCH,
MODIFY,
SHOW,
EMPTY,
SORT
};
int main()
{
Contact con;
InitContac(&con);
int input = 0;
do
{
menu();
printf("请选择: ");
scanf("%d", &input);
switch (input)
{
case ADD:
AddContacet(&con);
break;
case DELE:
DeleContact(&con);
break;
case SEARCH:
SearchContact(&con);
break;
case MODIFY:
ModefyContact(&con);
break;
case SHOW:
ShowContact(&con);
break;
case EMPTY:
EmptyContact(&con);
break;
case SORT:
SortContact(&con);
break;
case EXIT:
SaveContact(&con);
DestroyContact(&con);
printf("退出\n");
break;
default:
printf("没有此选项,请重新输入!\n");
break;
}
} while (input);
return 0;
}
(3)联系人的结构体的创建
我们使用一个结构体来创建通讯录人员的信息,每一个成员变量的大小都是使用
#define来定义的,方便后期结构体成员变量大小的调整,然后再创建一个结构体,里面有通讯录人员的信息,通讯录人员总数和通讯录的总容量,有静态版本和动态版版本的,这里使用的是动态版本的。
typedef struct PeopInfor
{
char name[NAME_MAX];
int age;
char sex[SEX_MAX];
char tele[TELE_MAX];
char addr[ADDR_MAX];
}PeopInfor;
静态版本
//typedef struct Contact
//{
// PeopInfor data[MAX];
// int sz;
//}Contact;
//动态版本
typedef struct Contact
{
PeopInfor* data;//通讯录人员的信息
int sz;//记录通讯录有多少人的信息
int capacity;//记录当前通讯录的总容量
}Contact;
(4)#define定义的符号
上面两个结构体创建的变量的大小都是#define定义的,方便后期对结构体成员变量大小的修改。
#define MAX 1000
#define NAME_MAX 10
#define SEX_MAX 4
#define TELE_MAX 12
#define ADDR_MAX 20
#define DEFAULT_SZ 3
#define INC_SZ 2
2.功能函数的实现
(1)初始化通讯录
下面通讯录的初始化有静态和动态版本,我们使用calloc函数来动态开辟内存空间,函数的功能是为num个大小为size的元素开辟一块空间,并把空间每个字节初始化为0;如果之前通讯录有保存过的数据,就会加载到通讯录中。
calloc函数原型:
void* calloc (size_t num,size_t size);
size_t num – num个元素
size_t size – 一个元素的大小(字节)
通讯录初始化,静态版本
//void InitContac(Contact* pc)
//{
// assert(pc);
// pc->sz = 0;
// memset(pc->data, 0, sizeof(pc->data));
//}
//通讯录初始化,动态版本
void InitContac(Contact* pc)
{
assert(pc);
pc->sz = 0;
PeopInfor* ptr = (PeopInfor*)calloc(DEFAULT_SZ, sizeof(PeopInfor));
if (ptr == NULL)
{
perror("InitContac::calloc");
return;
}
pc->data = ptr;
pc->capacity = DEFAULT_SZ;
LodeContact(pc);
}
//加载联系人
void LodeContact(Contact* pc)
{
FILE* pf = fopen("contact.txt", "rb");
if (NULL == pf)
{
perror("LodeContact");
}
else
{
PeopInfor temp = { 0 };
int i = 0;
while (fread(&temp, sizeof(PeopInfor), 1, pf))
{
Check_capacity(pc);
pc->data[i] = temp;
pc->sz++;
i++;
}
fclose(pf);
pf = NULL;
}
}
(2)增加联系人
首先判断空间是否足够,不够则增容,我们封装成了Check_capacity函数,方便后面调用,然后增加信息,输入对应内容。
//添加通讯录人员,静态版本
//void AddContacet(Contact* pc)
//{
// if (pc->sz == MAX)
// {
// printf("通讯录人员已满,无法添加\n");
// return;
// }
// int num = 0;
// printf("请输入要增加的人数:");
// scanf("%d", &num);
// int i = 0;
// for (i = 0; i < num; i++)
// {
// 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);
// pc->sz++;
// }
//}
//检查空间是否足够,不够则增容
void Check_capacity(Contact* pc)
{
if (pc->sz == pc->capacity)
{
PeopInfor* ptr = (PeopInfor*)realloc(pc->data, (pc->capacity + INC_SZ) * sizeof(PeopInfor));
if (ptr == NULL)
{
perror("Check_capacity::realloc");
return;
}
pc->capacity += INC_SZ;
pc->data = ptr;
printf("增容成功\n");
}
}
//添加通讯录人员,动态版本
void AddContacet(Contact* pc)
{
assert(pc);
Check_capacity(pc);
int num = 0;
printf("请输入要增加的人数:");
scanf("%d", &num);
int i = 0;
for (i = 0; i < num; i++)
{
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++;
}
}
打印结果:
(3)显示所有联系人的信息
使用for循环打印结构体中sz个信息
//显示通讯录名单
void ShowContact(const Contact* pc)
{
assert(pc);
printf("%-5s\t%-4s\t%-5s\t%-15s%-20s\n",
"姓名", "年龄", "性别", "电话", "地址");
for (int i = 0; i < pc->sz; i++)
{
printf("%-5s\t%-4d\t%-5s\t%-15s%-20s\n",
pc->data[i].name,
pc->data[i].age,
pc->data[i].sex,
pc->data[i].tele,
pc->data[i].addr);
}
}
打印结果:
(4)查找指定姓名的联系人
通过输入的姓名查找对应的下标,如果找到则返回下标,没找到则返回-1,为了方便后期的调用,使用FindByName函数封装起来;用返回的下标打印查找人的信息。
int FindByName(const Contact* pc, char name[])
{
assert(pc);
for (int pos = 0; pos < pc->sz; pos++)
{
if (strcmp(pc->data[pos].name, name) == 0)
{
return pos;
}
}
return -1;
}
//查找指定联系人
void SearchContact(Contact* pc)
{
assert(pc);
char name[NAME_MAX];
printf("请输入要查找人的姓名:");
scanf("%s", name);
int ret = FindByName(pc, name);
if (-1 == ret)
{
printf("要查找的人不存在\n");
return;
}
printf("%-5s\t%-4s\t%-5s\t%-15s%-20s\n",
"姓名", "年龄", "性别", "电话", "地址");
printf("%-5s\t%-4d\t%-5s\t%-15s%-20s\n",
pc->data[ret].name,
pc->data[ret].age,
pc->data[ret].sex,
pc->data[ret].tele,
pc->data[ret].addr);
}
显示结果:
(5)修改指定姓名的联系人
使用枚举我们可以一眼就看见选项对应的功能是什么,通过指定姓名修改指定的内容,也可以修改全部内容
enum Option
{
EXIT,
NAME,
AGE,
SEX,
TEL,
ADDR,
TOTAL
};
//修改指定联系人
void ModefyContact(Contact* pc)
{
assert(pc);
char name[NAME_MAX];
printf("请输入要修改人的姓名:");
scanf("%s", name);
int ret = FindByName(pc, name);
if (-1 == ret)
{
printf("要修改的人不存在\n");
return;
}
else
{
int num = 0;
do
{
printf("请输入你想修改此联系人的信息:\n");
printf("0.退出 1.姓名 2.年龄 3.性别 4.电话 5.地址 6.全部修改\n");
scanf("%d", &num);
switch (num)
{
case NAME:
printf("请输入名字:");
scanf("%s", pc->data[ret].name);
printf("修改成功!\n");
break;
case AGE:
printf("请输入年龄:");
scanf("%d", &(pc->data[ret].age));
printf("修改成功!\n");
break;
case SEX:
printf("请输入性别:");
scanf("%s", pc->data[ret].sex);
printf("修改成功!\n");
break;
case TEL:
printf("请输入电话:");
scanf("%s", pc->data[ret].tele);
printf("修改成功!\n");
break;
case ADDR:
printf("请输入地址:");
scanf("%s", pc->data[ret].addr);
printf("修改成功!\n");
break;
case TOTAL:
printf("请输入名字:");
scanf("%s", pc->data[ret].name);
printf("请输入年龄:");
scanf("%d", &(pc->data[ret].age));
printf("请输入性别:");
scanf("%s", pc->data[ret].sex);
printf("请输入电话:");
scanf("%s", pc->data[ret].tele);
printf("请输入地址:");
scanf("%s", pc->data[ret].addr);
printf("修改成功!\n");
break;
case EXIT:
printf("退出\n");
break;
default:
printf("无此选项\n");
break;
}
} while (num);
}
}
显示结果:
(6)删除指定姓名的联系人
找到指定人的下标并返回,以下标位置开始,把后面的内容向前覆盖,这样指定的位置就会删除
//删除指定联系人
void DeleContact(Contact* pc)
{
char name[NAME_MAX];
assert(pc);
printf("请输入要删除人的姓名:");
scanf("%s", name);
if (pc->sz == 0)
{
printf("通讯录为空,无法删除\n");
}
int ret = FindByName(pc, name);
if (-1 == ret)
{
printf("要删除的人不存在\n");
return;
}
for (int i = ret; i < pc->sz - 1; i++)
{
pc->data[i] = pc->data[i + 1];
}
pc->sz--;
printf("删除成功\n");
}
显示结果:
(7)按指定内容排序通讯录
使用qsort函数进行排序,排序的选项有按姓名排序和按年龄排序,排完序然后打印出来。
qsort函数原型:
void qsort (void* base, size_t num, size_t size,int (compar)(const void,const void*));
void* base – 待排序的数组的起始位置
size_t num – 元素的个数
size_t size – 一个元素的大小
int (compar)(const void,const void*) – 2个元素的比较函数
//清空所有联系人
void EmptyContact(Contact* pc)
{
pc->sz = 0;
printf("清空成功!\n");
}
//按姓名排序
int name_cmp(const void* e1, const void* e2)
{
return strcmp(((PeopInfor*)e1)->name, ((PeopInfor*)e2)->name);
}
//按年龄排序
int age_cmp(const void* e1, const void* e2)
{
return ((PeopInfor*)e1)->age - ((PeopInfor*)e2)->age;
}
//按指定内容排序所有联系人
void SortContact(Contact* pc)
{
printf("********* 请选择排序方式(升序) **********\n");
printf("************ 1.姓名 2.年龄 *************\n");
printf("**********************************************\n");
int input = 0;
scanf("%d", &input);
switch (input)
{
case 1:
qsort(pc->data, pc->sz, sizeof(pc->data[0]), name_cmp);
break;
case 2:
qsort(pc->data, pc->sz, sizeof(pc->data[0]), age_cmp);
break;
default:
printf("无此选项\n");
break;
}
printf("%-5s\t%-4s\t%-5s\t%-15s%-20s\n",
"姓名", "年龄", "性别", "电话", "地址");
for (int i = 0; i < pc->sz; i++)
{
printf("%-5s\t%-4d\t%-5s\t%-15s%-20s\n",
pc->data[i].name,
pc->data[i].age,
pc->data[i].sex,
pc->data[i].tele,
pc->data[i].addr);
}
printf("排序成功!\n");
}
显示结果:
(8)清空通讯录
把结构体中sz变为0就没有信息了
//清空所有联系人
void EmptyContact(Contact* pc)
{
pc->sz = 0;
printf("清空成功!\n");
}
显示结果:
(9)保存通讯录的信息
我们以只写wb打开一个二进制文件,把地址放在指针pf里,然后使用for循环把sz个信息写到pf里。
fwrite函数的原型:
size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream)
ptr-- 这是指向要被写入的元素数组的指针。
size-- 这是要被写入的每个元素的大小,以字节为单位。
nmemb-- 这是元素的个数,每个元素的大小为 size 字节。
stream-- 这是指向 FILE 对象的指针,该 FILE 对象指定了一个输出流。
//保存通讯录
void SaveContact(Contact* pc)
{
FILE* pf = fopen("contact.txt", "wb");
if (NULL == pf)
{
perror("SaveContact");
}
else
{
int i = 0;
for (i = 0; i < pc->sz; i++)
{
fwrite(pc->data + i, sizeof(PeopInfor), 1, pf);
}
fclose(pf);
pf = NULL;
printf("保存成功!\n");
}
}
(10)释放内存
通讯录中使用的是动态开辟的空间,是在堆区上面使用的,需要我们释放,使用free函数,一层一层释放。
void DestroyContact(Contact* pc)
{
free(pc->data);
pc->data = NULL;
pc->capacity = 0;
pc->sz = 0;
pc = NULL;
}
三、代码呈现
(1)test.c
#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"
void menu()
{
printf("*************************************\n");
printf("******** 1.add 2.dele ********\n");
printf("******** 3.search 4.modify ********\n");
printf("******** 5.show 6.empty ********\n");
printf("******** 7.sort 0.exit ********\n");
printf("*************************************\n");
}
enum Option
{
EXIT,
ADD,
DELE,
SEARCH,
MODIFY,
SHOW,
EMPTY,
SORT
};
int main()
{
Contact con;
InitContac(&con);
int input = 0;
do
{
menu();
printf("请选择: ");
scanf("%d", &input);
switch (input)
{
case ADD:
AddContacet(&con);
break;
case DELE:
DeleContact(&con);
break;
case SEARCH:
SearchContact(&con);
break;
case MODIFY:
ModefyContact(&con);
break;
case SHOW:
ShowContact(&con);
break;
case EMPTY:
EmptyContact(&con);
break;
case SORT:
SortContact(&con);
break;
case EXIT:
SaveContact(&con);
DestroyContact(&con);
printf("退出\n");
break;
default:
printf("没有此选项,请重新输入!\n");
break;
}
} while (input);
return 0;
}
(2)contact.c
#define _CRT_SECURE_NO_WARNINGS 1
#include"contact3.h"
通讯录初始化,静态版本
//void InitContac(Contact* pc)
//{
// assert(pc);
// pc->sz = 0;
// memset(pc->data, 0, sizeof(pc->data));
//}
//通讯录初始化,动态版本
void InitContac(Contact* pc)
{
assert(pc);
pc->sz = 0;
PeopInfor* ptr = (PeopInfor*)calloc(DEFAULT_SZ, sizeof(PeopInfor));
if (ptr == NULL)
{
perror("InitContac::calloc");
return;
}
pc->data = ptr;
pc->capacity = DEFAULT_SZ;
LodeContact(pc);
}
//销毁通讯录
void DestroyContact(Contact* pc)
{
free(pc->data);
pc->data = NULL;
pc->capacity = 0;
pc->sz = 0;
pc = NULL;
}
//添加通讯录人员,静态版本
//void AddContacet(Contact* pc)
//{
// if (pc->sz == MAX)
// {
// printf("通讯录人员已满,无法添加\n");
// return;
// }
// int num = 0;
// printf("请输入要增加的人数:");
// scanf("%d", &num);
// int i = 0;
// for (i = 0; i < num; i++)
// {
// 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);
// pc->sz++;
// }
//}
void Check_capacity(Contact* pc)
{
if (pc->sz == pc->capacity)
{
PeopInfor* ptr = (PeopInfor*)realloc(pc->data, (pc->capacity + INC_SZ) * sizeof(PeopInfor));
if (ptr == NULL)
{
perror("Check_capacity::realloc");
return;
}
pc->capacity += INC_SZ;
pc->data = ptr;
printf("增容成功\n");
}
}
//添加通讯录人员,动态版本
void AddContacet(Contact* pc)
{
assert(pc);
Check_capacity(pc);
int num = 0;
printf("请输入要增加的人数:");
scanf("%d", &num);
int i = 0;
for (i = 0; i < num; i++)
{
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++;
}
}
//显示通讯录名单
void ShowContact(const Contact* pc)
{
assert(pc);
printf("%-5s\t%-4s\t%-5s\t%-15s%-20s\n",
"姓名", "年龄", "性别", "电话", "地址");
for (int i = 0; i < pc->sz; i++)
{
printf("%-5s\t%-4d\t%-5s\t%-15s%-20s\n",
pc->data[i].name,
pc->data[i].age,
pc->data[i].sex,
pc->data[i].tele,
pc->data[i].addr);
}
}
int FindByName(const Contact* pc, char name[])
{
assert(pc);
for (int pos = 0; pos < pc->sz; pos++)
{
if (strcmp(pc->data[pos].name, name) == 0)
{
return pos;
}
}
return -1;
}
//删除指定联系人
void DeleContact(Contact* pc)
{
char name[NAME_MAX];
assert(pc);
printf("请输入要删除人的姓名:");
scanf("%s", name);
if (pc->sz == 0)
{
printf("通讯录为空,无法删除\n");
}
int ret = FindByName(pc, name);
if (-1 == ret)
{
printf("要删除的人不存在\n");
return;
}
for (int i = ret; i < pc->sz - 1; i++)
{
pc->data[i] = pc->data[i + 1];
}
pc->sz--;
printf("删除成功\n");
}
//查找指定联系人
void SearchContact(Contact* pc)
{
assert(pc);
char name[NAME_MAX];
printf("请输入要查找人的姓名:");
scanf("%s", name);
int ret = FindByName(pc, name);
if (-1 == ret)
{
printf("要查找的人不存在\n");
return;
}
printf("%-5s\t%-4s\t%-5s\t%-15s%-20s\n",
"姓名", "年龄", "性别", "电话", "地址");
printf("%-5s\t%-4d\t%-5s\t%-15s%-20s\n",
pc->data[ret].name,
pc->data[ret].age,
pc->data[ret].sex,
pc->data[ret].tele,
pc->data[ret].addr);
}
enum Option
{
EXIT,
NAME,
AGE,
SEX,
TEL,
ADDR,
TOTAL
};
//修改指定联系人
void ModefyContact(Contact* pc)
{
assert(pc);
char name[NAME_MAX];
printf("请输入要修改人的姓名:");
scanf("%s", name);
int ret = FindByName(pc, name);
if (-1 == ret)
{
printf("要修改的人不存在\n");
return;
}
else
{
int num = 0;
do
{
printf("请输入你想修改此联系人的信息:\n");
printf("0.退出 1.姓名 2.年龄 3.性别 4.电话 5.地址 6.全部修改\n");
scanf("%d", &num);
switch (num)
{
case NAME:
printf("请输入名字:");
scanf("%s", pc->data[ret].name);
printf("修改成功!\n");
break;
case AGE:
printf("请输入年龄:");
scanf("%d", &(pc->data[ret].age));
printf("修改成功!\n");
break;
case SEX:
printf("请输入性别:");
scanf("%s", pc->data[ret].sex);
printf("修改成功!\n");
break;
case TEL:
printf("请输入电话:");
scanf("%s", pc->data[ret].tele);
printf("修改成功!\n");
break;
case ADDR:
printf("请输入地址:");
scanf("%s", pc->data[ret].addr);
printf("修改成功!\n");
break;
case TOTAL:
printf("请输入名字:");
scanf("%s", pc->data[ret].name);
printf("请输入年龄:");
scanf("%d", &(pc->data[ret].age));
printf("请输入性别:");
scanf("%s", pc->data[ret].sex);
printf("请输入电话:");
scanf("%s", pc->data[ret].tele);
printf("请输入地址:");
scanf("%s", pc->data[ret].addr);
printf("修改成功!\n");
break;
case EXIT:
printf("退出\n");
break;
default:
printf("无此选项\n");
break;
}
} while (num);
}
}
//清空所有联系人
void EmptyContact(Contact* pc)
{
pc->sz = 0;
printf("清空成功!\n");
}
//按姓名排序
int name_cmp(const void* e1, const void* e2)
{
return strcmp(((PeopInfor*)e1)->name, ((PeopInfor*)e2)->name);
}
//按年龄排序
int age_cmp(const void* e1, const void* e2)
{
return ((PeopInfor*)e1)->age - ((PeopInfor*)e2)->age;
}
//按指定内容排序所有联系人
void SortContact(Contact* pc)
{
printf("********* 请选择排序方式(升序) **********\n");
printf("************ 1.姓名 2.年龄 *************\n");
printf("**********************************************\n");
int input = 0;
scanf("%d", &input);
switch (input)
{
case 1:
qsort(pc->data, pc->sz, sizeof(pc->data[0]), name_cmp);
break;
case 2:
qsort(pc->data, pc->sz, sizeof(pc->data[0]), age_cmp);
break;
default:
printf("无此选项\n");
break;
}
printf("%-5s\t%-4s\t%-5s\t%-15s%-20s\n",
"姓名", "年龄", "性别", "电话", "地址");
for (int i = 0; i < pc->sz; i++)
{
printf("%-5s\t%-4d\t%-5s\t%-15s%-20s\n",
pc->data[i].name,
pc->data[i].age,
pc->data[i].sex,
pc->data[i].tele,
pc->data[i].addr);
}
printf("排序成功!\n");
}
//保存通讯录
void SaveContact(Contact* pc)
{
FILE* pf = fopen("contact.txt", "wb");
if (NULL == pf)
{
perror("SaveContact");
}
else
{
int i = 0;
for (i = 0; i < pc->sz; i++)
{
fwrite(pc->data + i, sizeof(PeopInfor), 1, pf);
}
fclose(pf);
pf = NULL;
printf("保存成功!\n");
}
}
//加载联系人
void LodeContact(Contact* pc)
{
FILE* pf = fopen("contact.txt", "rb");
if (NULL == pf)
{
perror("LodeContact");
}
else
{
PeopInfor temp = { 0 };
int i = 0;
while (fread(&temp, sizeof(PeopInfor), 1, pf))
{
Check_capacity(pc);
pc->data[i] = temp;
pc->sz++;
i++;
}
fclose(pf);
pf = NULL;
}
}
(3)contact.h
#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<string.h>
#define NAME_MAX 10
#define SEX_MAX 4
#define TELE_MAX 12
#define ADDR_MAX 20
#define DEFAULT_SZ 3
#define INC_SZ 2
typedef struct PeopInfor
{
char name[NAME_MAX];
int age;
char sex[SEX_MAX];
char tele[TELE_MAX];
char addr[ADDR_MAX];
}PeopInfor;
静态版本
//typedef struct Contact
//{
// PeopInfor data[MAX];
// int sz;
//}Contact;
//动态版本
typedef struct Contact
{
PeopInfor* data;//通讯录人员的信息
int sz;//记录通讯录有多少人的信息
int capacity;//记录当前通讯录的总容量
}Contact;
//通讯录初始化
void InitContac(Contact* pc);
//销毁通讯录
void DestroyContact(Contact* pc);
//添加通讯录人员
void AddContacet(Contact* pc);
//显示通讯录名单
void ShowContact(const Contact* pc);
//删除指定联系人
void DeleContact(Contact* pc);
//查找指定联系人
void SearchContact(Contact* pc);
//修改指定联系人
void ModefyContact(Contact* pc);
//清空所有联系人
void EmptyContact(Contact* pc);
//按姓名排序所有联系人
void SortContact(Contact* pc);
//保存通讯录
void SaveContact(Contact* pc);
//加载联系人
void LodeContact(Contact* pc);
看到这了,如果你似懂非懂就在此留下你阅读的痕迹吧😎