通讯录要求
我们需要使用C语言创建一个通讯录,要用通讯录具体实现存储联系人的地址,姓名,电话,性别,年龄
要求我们要使用动态内存分配,通讯录存放了多少人就占多少个空间
功能包括
1.增加联系人
2.删除联系人
3.修改联系人
4.查找联系人
5.展示联系人
思路讲解
这里我们主要要用到C语言数据结构的顺序表来进行实现,关于顺序表的实现,详见这篇文章C语言顺序表这里就不过多描述顺序表的实现了
这个通讯录的底层逻辑就是顺序表
只是把顺序表存放的内置类型变成了自定义类型,就像下面这张图
我们写通讯录的时候其实就是把顺序表存放的内置类型替换成了我们的自定义类型,本质上还是顺序表
代码实现
我们这里分为多个文件去写这个通讯录
1.test.c这里是方便测试代码的功能
2.addressname.c这里是实现通讯录的功能
3.addressname.h通讯录需要的头文件
4.seqlist.c顺序表的实现功能
5.seqlist.h顺序表实现需要的头文件
先来看看主函数
这个代码是存放在test.c文件下面
# define _CRT_SECURE_NO_WARNINGS
# include"head.h"
void menu()
{
printf("**********通讯录**********\n");
printf("请选择相应操作的序号\n");
printf("1.添加联系人\n");
printf("2.删除联系人\n");
printf("3.修改联系人\n");
printf("4.查找联系人\n");
printf("5.展示联系人\n");
printf("0.退出\n");
printf("*************************\n");
}
int main()
{
Contact con;//用seqlist结构体重命名为Contact在创建了一个con结构体变量
int op = -1;
ContactInit(&con);
do {
menu();
printf("请选择您的操作:\n");
scanf("%d",&op);
switch (op)
{
case 1:
ContactAdd(&con);
break;
case 2:
ContactDel(&con);
break;
case 3:
ContactModify(&con);
break;
case 4:
ContactFind(&con);
break;
case 5:
ContactShow(&con);
break;
case 0:
printf("退出通讯录\n");
break;
default:
printf("输入错误,请重新选择您的操作!\n");
break;
}
} while (op != 0);
ContactDesTroy(&con);
return 0;
这里就是我们的最上层代码的实现,也就是打印菜单,让用户自行选择要操作通讯录内容的界面,并且初始化了顺序表(也就是通讯录)
下面是通讯录的头文件addressname.h
#pragma once
#define NAME_MAX 20
#define GENDER_MAX 10
#define TEL_MAX 20
#define ADDR_MAX 100
struct personinformation
{
char name[NAME_MAX];
char gender[GENDER_MAX];
int age;
char tel[TEL_MAX];
char addr[ADDR_MAX];
};
typedef struct personinformation peoinfo;//重定义方便代码书写
typedef struct seqlist Contact;//前置声明,创建使用通讯录实际上是使用的是顺序表,给顺序表改个名字叫做通讯录
void ContactInit(Contact* con);
//通讯录的销毁
void ContactDesTroy(Contact* con);
//通讯录添加数据
void ContactAdd(Con