我们设计的要求
存储多少个人的信息我们使用宏,这样方便修改
建立三个文件
先从主函数入手
为了持续多次,实现操作,我们利用循环,循环次数未知,我们只能选择while循环,do-while循环,我们始终要进行一次判断操作,所以我们使用do while循环
进入循环我们首先要打印菜单
根据菜单选择操作,所以还有一个输入
void menu()
{
printf("***************************************\n");
printf("***** 1.add 2.del *****\n");
printf("***** 3.search 4.alter *****\n");
printf("***** 5.show 6.empty *****\n");
printf("***** 7.sort 0.exit *****\n");
printf("***************************************\n");
}
int main()
{
do
{
menu();
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:
break;
default:
break;
}
} while (input);
}
输入对应菜单的数字,然后实现功能,输入错误,重新输入
我们通讯录联系人的信息各种各样,类型不同,所以我们想到了,结构体可以存储不同的变量
那么我们就来先进行结构体的声明,还有结构体变量的创建
声明
#define num 1000
#define num_name 20
#define num_sex 5
#define num_tel 20
#define num_address 30
typedef struct PeoInfo
{
char name[num_name];
char sex[num_sex];
int age;
char tel[num_tel];
char address[num_address];
}PeoInfo;
typedef struct Contact
{
PeoInfo data[num];//联系人数量
int sz;//存有联系人数量
}Contact;
变量的创建
//创建结构体
Contact con;
创建好结构体我们要对结构体进行初始化
利用一个函数IntiContact进行初始化,我们函数的参数传什么,我们首选传地址的方式,因为直接传内容,要对内容进行临时的拷贝,这样会降低性能,我们考虑传结构体的地址,结构体的名字叫con
函数设计
函数的实现
void IntiContact(Contact* pc)//初始化电话簿
{
pc->sz = 0;
memset(pc->data, 0, sizeof(pc->data));
}
函数的形参我们利用一个结构体指针来接收
memset函数进行内容的设置
我们来一步一步的实现功能
add,增加联系人
我们输入了1,进行增加联系人的选项,我们创建一个函数AddContact进行增加,
所以我们函数这样设计
函数内容我们放到address_book.c内封装
进入函数我们要判断电话簿满了没有
如果不满,我们进行添加
函数的实现代码
void AddContact(Contact* pc)//增加联系人
{
if (pc->sz == num)
{
printf("通讯录已经满了\n");
return;
}
printf("请输入姓名\n");
scanf("%s", pc->data[pc->sz].name);
printf("请输入性别\n");
scanf("%s", pc->data[pc->sz].sex);
printf("请输入年龄\n");
scanf("%d", &(pc->data[pc->sz].age));
printf("请输入电话\n");
scanf("%s", pc->data[pc->sz].tel);
printf("请输入地址\n");
scanf("%s", pc->data[pc->sz].address);
pc->sz++;
}
最后sz要++,因为联系人多了一个
我们写程序的时候不一定要循规蹈矩,我们添加完联系人,我们就看看,有没有添加进去
我们先实现输入5的功能,显示电话簿
创建函数
我们电话簿联系人很多所以我们要通过循环进行打印
函数的实现
void ShowContact(Contact* pc)//展示电话簿
{
int i = 0;
printf("%-20s\t%-5s\t%-3s\t%-12s\t%-20s\n", "姓名", "性别", "年龄", "电话", "地址");
for (i = 0; i < pc->sz; i++)
{
printf("%-20s\t%-5s\t%-3d\t%-12s\t%-20s\n",
pc->data[i].name,
pc->data[i].sex,
pc->data[i].age,
pc->data[i].tel,
pc->data[i].address);
}
}
在开头我们打印"姓名", "性别", "年龄", "电话", "地址",让读者明白以后打印完下面对应的东西是什么。
然后我们得到了
好像有模有样了
下面实现输入2,删除功能
删除联系人前,还要判断电话簿是否有联系人
我们删除联系人,需要输入联系人,然后在电话簿查找联系人是否存在,功能2,3,4都需要查找联系人,我们可以封装一个函数来专门查找联系人,需要查找联系人的时候,调用这个函数就可以了
查找联系人的函数
int FindName(Contact* pc, char name[])//查找某一个联系人
{
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)//删除联系人
{
if (pc->sz == 0)
{
printf("通讯录没有联系人,无法删除\n");
return;
}
char name[20];
printf("请输入要删除的名字\n");
scanf("%s", name);
int ret=FindName(pc, name);
if (ret == -1)
{
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");
}
接下来实现输入3,搜索功能
搜索一个人,先输入,再通过我们的查找函数在电话簿查找,联系人是否存在,不存在我们就搜索失败,存在就打印出来
函数的实现
void SearchContact(Contact* pc)//搜索联系人
{
char name[20];
printf("请输入要查找的联系人\n");
scanf("%s", name);
int ret = FindName(pc, name);
if (ret == -1)
{
printf("没有该联系人\n");
return;
}
printf("%-20s\t%-5s\t%-3s\t%-12s\t%-20s\n", "姓名", "性别", "年龄", "电话", "地址");
printf("%-20s\t%-5s\t%-3d\t%-12s\t%-20s\n",
pc->data[ret].name,
pc->data[ret].sex,
pc->data[ret].age,
pc->data[ret].tel,
pc->data[ret].address);
}
输入4,实现修改联系人功能
修改联系人前,我们也需要搜索联系人,判断联系人是否存在,然后出现输入联系人的信息
函数的实现
void AlterContact(Contact* pc)
{
printf("请输入要修改人的名字\n");
char name[20];
scanf("%s", name);
int ret = FindName(pc, name);
if (ret == -1)
{
printf("电话簿没有此人\n");
return;
}
printf("请输入新姓名\n");
scanf("%s", pc->data[ret].name);
printf("请输入新性别\n");
scanf("%s", pc->data[ret].sex);
printf("请输入新年龄\n");
scanf("%d", &(pc->data[ret].age));
printf("请输入新电话\n");
scanf("%s", pc->data[ret].tel);
printf("请输入新地址\n");
scanf("%s", pc->data[ret].address);
printf("修改成功\n");
}
输入6,清空电话簿
清空功能,和我们初始化大同小异
void EmptyContact(Contact* pc)//清空电话簿
{
pc->sz = 0;
memset(pc->data, 0, sizeof(pc->data));
printf("清空电话簿成功\n");
}
输入7,我们进行结构体的排序
我们前面也有接受使用qsort排序,链接http://t.csdn.cn/Ur4HK
int Contact_sort_name(void* e1, void* e2)
{
return strcmp((Contact*)e1, (Contact*)e2);
}
简易通讯录的框架就是这样,后续我还会继续优化
原码
test.c
#define _CRT_SECURE_NO_WARNINGS 1
#include "address_book.h"
void menu()
{
printf("***************************************\n");
printf("***** 1.add 2.del *****\n");
printf("***** 3.search 4.alter *****\n");
printf("***** 5.show 6.empty *****\n");
printf("***** 7.sort 0.exit *****\n");
printf("***************************************\n");
}
int main()
{
int input = 0;
//创建结构体
Contact con;
//初始化
IntiContact(&con);
do
{
menu();
scanf("%d", &input);
switch (input)
{
case 1: AddContact(&con);
break;
case 2: DelContact(&con);
break;
case 3: SearchContact(&con);
break;
case 4: AlterContact(&con);
break;
case 5: ShowContact(&con);
break;
case 6: EmptyContact(&con);
break;
case 7: qsort(&con, con.sz, sizeof(con.data[0]), Contact_sort_name);
printf("排序成功\n");
break;
case 0: printf("退出通讯录\n");
break;
default: printf("输入错误请重新输入\n");
break;
}
} while (input);
return 0;
}
address_book.c
#define _CRT_SECURE_NO_WARNINGS 1
#include "address_book.h"
void IntiContact(Contact* pc)//初始化电话簿
{
pc->sz = 0;
memset(pc->data, 0, sizeof(pc->data));
}
void AddContact(Contact* pc)//增加联系人
{
if (pc->sz == num)
{
printf("通讯录已经满了\n");
return;
}
printf("请输入姓名\n");
scanf("%s", pc->data[pc->sz].name);
printf("请输入性别\n");
scanf("%s", pc->data[pc->sz].sex);
printf("请输入年龄\n");
scanf("%d", &(pc->data[pc->sz].age));
printf("请输入电话\n");
scanf("%s", pc->data[pc->sz].tel);
printf("请输入地址\n");
scanf("%s", pc->data[pc->sz].address);
pc->sz++;
}
void ShowContact(Contact* pc)//展示电话簿
{
int i = 0;
printf("%-20s\t%-5s\t%-3s\t%-12s\t%-20s\n", "姓名", "性别", "年龄", "电话", "地址");
for (i = 0; i < pc->sz; i++)
{
printf("%-20s\t%-5s\t%-3d\t%-12s\t%-20s\n",
pc->data[i].name,
pc->data[i].sex,
pc->data[i].age,
pc->data[i].tel,
pc->data[i].address);
}
}
int FindName(Contact* pc, char name[])//查找某一个联系人
{
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)//删除联系人
{
if (pc->sz == 0)
{
printf("通讯录没有联系人,无法删除\n");
return;
}
char name[20];
printf("请输入要删除的名字\n");
scanf("%s", name);
int ret=FindName(pc, name);
if (ret == -1)
{
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(Contact* pc)//搜索联系人
{
char name[20];
printf("请输入要查找的联系人\n");
scanf("%s", name);
int ret = FindName(pc, name);
if (ret == -1)
{
printf("没有该联系人\n");
return;
}
printf("%-20s\t%-5s\t%-3s\t%-12s\t%-20s\n", "姓名", "性别", "年龄", "电话", "地址");
printf("%-20s\t%-5s\t%-3d\t%-12s\t%-20s\n",
pc->data[ret].name,
pc->data[ret].sex,
pc->data[ret].age,
pc->data[ret].tel,
pc->data[ret].address);
}
void AlterContact(Contact* pc)
{
printf("请输入要修改人的名字\n");
char name[20];
scanf("%s", name);
int ret = FindName(pc, name);
if (ret == -1)
{
printf("电话簿没有此人\n");
return;
}
printf("请输入新姓名\n");
scanf("%s", pc->data[ret].name);
printf("请输入新性别\n");
scanf("%s", pc->data[ret].sex);
printf("请输入新年龄\n");
scanf("%d", &(pc->data[ret].age));
printf("请输入新电话\n");
scanf("%s", pc->data[ret].tel);
printf("请输入新地址\n");
scanf("%s", pc->data[ret].address);
printf("修改成功\n");
}
void EmptyContact(Contact* pc)//清空电话簿
{
pc->sz = 0;
memset(pc->data, 0, sizeof(pc->data));
printf("清空电话簿成功\n");
}
int Contact_sort_name(void* e1, void* e2)
{
return strcmp((Contact*)e1, (Contact*)e2);
}
address_book.h
#pragma once
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define num 1000
#define num_name 20
#define num_sex 5
#define num_tel 20
#define num_address 30
typedef struct PeoInfo
{
char name[num_name];
char sex[num_sex];
int age;
char tel[num_tel];
char address[num_address];
}PeoInfo;
typedef struct Contact
{
PeoInfo data[num];//联系人数量
int sz;//存有联系人数量
}Contact;
void IntiContact(Contact* pc);//初始化
void AddContact(Contact* pc);//增加联系人
void ShowContact(Contact* pc);//展示电话簿
void DelContact(Contact* pc);//删除联系人
void SearchContact(Contact* pc);//搜索联系人
void EmptyContact(Contact* pc);//清空电话簿
int Contact_sort_name(void* e1, void* e2);//qsort