一、前言
今天我们来用C语言实现一个通讯录的程序,需要实现的功能有:
- 添加联系人
- 删除联系人
- 查找联系人
- 修改联系人
- 显示所有联系人的信息
- 按姓名对联系人进行排序
二、代码实现
在这里我们创建三个文件:
Contact.h需要写函数声明
Contact.c用来写程序主体函数的内容
main.c用来写程序菜单以及整体大致框架的内容
2.1 通讯录结构体定义
对于通讯录里的个人信息我们采用结构体来定义
个人信息包括:姓名、年龄、性别、电话以及住址
我们不仅要存放没个人的信息
还需要知道通讯录中存在联系人的数量
因此我们还需要把个人信息以及联系人数量再创建一个结构体类型存放
同时对于个人信息中数组的大小可以不使用数字初始化,而是在头文件中声明
这样我们在后期修改数据时可以只修改头文件中的数据即可
2.2 整体框架
首先在main函数里将程序框架搭建,通过menu将菜单打印出来,并使用do while和switch进行选择
接下来我们对通讯录进行初始化
在这里我们选择使用memset函数进行初始化
2.3 添加联系人
这里的num是记录通讯录中现在存放的联系人的数量
MAX是通讯录可以记录的联系人的最大数量
2.4 删除联系人
因为删除联系人、查找联系人、修改联系人都需要找到联系人的信息
因此我们可以先封装一个FindName函数用来后续进行联系人信息的查找
这里我们对数组内的元素进行遍历,并使用strcmp函数进行字符串比较,如果成功找到了就返回下标,否则返回-1
下面是删除联系人的代码:
2.5 查找联系人
在这里我们同样调用FindName函数进行对需要查找的联系人的名字的比较
查找成功后打印出指定联系人的信息
其中"-10%s\t"中的"-"表示左对齐
"10"表示宽度,字符串不够的用空格代替
"\t"相当于Tab键
同时因为我们在这里只是查找联系人并不修改里面的数据,因此我们需要使用const对Contact* pc进行保护,防止意外修改,增强程序的健壮性
2.6 修改联系人
修改操作还是比较简单的
可以看作两步进行,第一步查找到指定联系人的位置,第二步重新输入联系人的数据
当然也可以找到信息中的某一项进行修改
使用do while和switch来构建相关的框架,这里就不再做过多的赘述
2.7 显示所有联系人的信息
这里同样不需要对个人信息进行修改,因此也要使用const修饰变量
2.8 按姓名对联系人进行排序
这里使用qsort这个库函数进行排序
我们需要在第四个参数自定义一个比较函数name_sort确定排序的规则
三、源码
3.1 Contact.h(函数的声明)
#include<stdio.h>
#include<string.h>
#include<assert.h>
#define MAX 200//通讯录所能存放的人数
#define Max_name 20
#define Max_sex 5
#define Max_tele 12
#define Max_addr 50
typedef struct PeoInfo
{
char name[Max_name];
int age;
char sex[Max_sex];
char tele[Max_tele];
char addr[Max_addr];
}PeoInfo;
typedef struct Contact
{
PeoInfo data[MAX];
int num;
}Contact;
//通讯录初始化
void InitContact(Contact* pc);
//添加联系人
void AddContact(Contact* pc);
//删除联系人
void DleContact(Contact* pc);
//查找联系人
void SerchContact(const Contact* pc);
//修改联系人
void ModifyContact(Contact* pc);
//显示所有联系人的信息
void ShowContact(const Contact* pc);
//按姓名对联系人进行排序
void SortContact(Contact* pc);
//释放空间
void DestroyContact(Contact* pc);
3.2 Contact.c(函数的实现)
#include"Contact.h"
void InitContact(Contact* pc)
{
assert(pc);
memset(pc->data, 0, sizeof(pc->data));
pc->num = 0;
}
void AddContact(Contact* pc)
{
assert(pc);
if (pc->num == MAX)
{
printf("通讯录已满\n");
return;
}
printf("请输入名字:");
scanf("%s", pc->data[pc->num].name);
printf("请输入年龄:");
scanf("%d", &(pc->data[pc->num].age));
printf("请输入性别:");
scanf("%s", pc->data[pc->num].sex);
printf("请输入电话:");
scanf("%s", pc->data[pc->num].tele);
printf("请输入住址:");
scanf("%s", pc->data[pc->num].addr);
pc->num++;
printf("添加成功\n");
}
int FindName(const Contact* pc, char name[])
{
int i = 0;
for (i = 0; i < pc->num; i++)
{
if (strcmp(pc->data[i].name, name) == 0)
{
return i;
}
return -1;
}
}
void DleContact(Contact* pc)
{
assert(pc);
if (pc->num == 0)
{
printf("通讯录为空,无法删除\n");
return;
}
char name[Max_name] = { 0 };
printf("请输入要删除的联系人:");
scanf("%s", &name);
int del = FindName(pc,name);
if (del == -1)
{
printf("要删除的联系人不存在\n");
return;
}
int i = 0;
for (i = del; i < pc->num - 1; i++)
{
pc->data[i] = pc->data[i + 1];
}
pc->num--;
printf("成功删除联系人\n");
}
void SerchContact(const Contact* pc)
{
assert(pc);
char name[Max_name] = { 0 };
printf("请输入要查找的联系人:");
scanf("%s", &name);
int pos = FindName(pc, name);
if (pos == -1)
printf("要查找的联系人不存在\n");
else
{
printf("%-10s\t%-4s\t%-5s\t%-15s\t%-30s\n", "姓名", "年龄", "性别", "电话", "住址");
printf("%-10s\t%-4s\t%-5s\t%-15s\t%-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)
{
assert(pc);
char name[Max_name] = { 0 };
printf("请输入要查找的联系人:");
scanf("%s", &name);
int pos = FindName(pc, name);
if (pos == -1)
printf("要修改的联系人不存在\n");
else
{
printf("请输入名字:");
scanf("%s", pc->data[pc->num].name);
printf("请输入年龄:");
scanf("%d",&(pc->data[pc->num].age));
printf("请输入性别:");
scanf("%s", pc->data[pc->num].sex);
printf("请输入电话:");
scanf("%s", pc->data[pc->num].tele);
printf("请输入住址:");
scanf("%s", pc->data[pc->num].addr);
printf("修改成功\n");
}
}
void ShowContact(const Contact* pc)
{
assert(pc);
int i = 0;
printf("%-10s\t%-4s\t%-5s\t%-15s\t%-30s\n", "姓名", "年龄", "性别", "电话", "住址");
for (i = 0; i < pc->num; i++)
{
printf("%-10s\t%-4s\t%-5s\t%-15s\t%-30s\n",
pc->data[i].name,
pc->data[i].age,
pc->data[i].sex,
pc->data[i].tele,
pc->data[i].addr);
}
}
int name_sort(const void* str1, const void* str2)
{
return(strcmp(((Contact*)str1)->data->name, ((Contact*)str2)->data->name));
}
void SortContact(Contact* pc)
{
assert(pc);
qsort(pc->data, pc->num, sizeof(pc->data[0]), name_sort);
printf("排序完成\n");
ShowContact(pc);
}
3.3 main.c(整体框架搭建)
#include"Contact.h"
void menu()
{
printf("********************************\n");
printf("****** 1.Add 2.Del ******\n");
printf("****** 3.Serch 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:
DleContact(&con);
break;
case 3:
SerchContact(&con);
break;
case 4:
ModifyContact(&con);
break;
case 5:
ShowContact(&con);
break;
case 6:
SortContact(&con);
break;
case 0:
printf("退出程序\n");
break;
default:
printf("输入错误,请重新输入\n");
break;
}
} while (input);
return 0;
}