目录
一.通讯录所具有的功能
1.可以保存100个人的信息
2. 增加人的信息(名字、年龄、性别、电话、住址)
3.删除指定联系人的信息
4.查找指定联系人的信息
5.修改指定联系人的信息
6.排序通讯录的信息
7.显示所有联系人的信息
二.通讯录基本框架的搭建
(1)通讯录菜单设置
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;
do
{
menu();
printf("请选择:>\n");
scanf("%d", &input);
switch (input)
{
case 1:
break;
case 2:
break;
case 3:
break;
case 4:
break;
case 5:
break;
case 6:
break;
case 0:
printf("退出通讯录\n");
break;
default:
printf("选择错误,请重新选择!\n");
break;
}
} while (input);
return 0;
}
注:这里在书写switch语句时,很容易忘记相应数字所对应的功能,因此使用枚举的方式来进行优化处理。
- 优化后
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");
}
enum Option
{
EXIT,//0
ADD,
DEL,
SEARCH,
MODIFY,
SHOW,
SORT
};
int main()
{
int input = 0;
do
{
menu();
printf("请选择:>\n");
scanf("%d", &input);
switch (input)
{
case ADD:
break;
case DEL:
break;
case SEARCH:
break;
case MODIFY:
break;
case SHOW:
break;
case SORT:
break;
case EXIT:
printf("退出通讯录\n");
break;
default:
printf("选择错误,请重新选择!\n");
break;
}//这样写相关功能的顺序也可以颠倒
} while (input);
return 0;
}
(2)人的信息的处理
#define NAME_MAX 20
#define SEX_MAX 5
#define TELE_MAX 12
#define ADDR_MAX 20
#define PEOPLE_MAX 100
typedef struct PeoInfo
{
char name[NAME_MAX];
int age;
char sex[SEX_MAX];
char tele[TELE_MAX];
char addr[ADDR_MAX];
}PeoInfo;//进行类型重命名,方便书写
typedef struct Contact
{
PeoInfo data[PEOPLE_MAX];//data数组用来存放100个人的信息
int num;//记录当前通讯录中已经存放的人的信息的个数
}Contact;
三.创建通讯录
- 创建开始
Contact con;
(1)初始化通讯录
void InitContact(Contact* pc)
{
assert(pc);//保证指针的有效性
pc->num = 0;
memset(pc->data, 0, sizeof(pc->data));//将整个数组初始化为0
}
(2)增添联系人
void AddContact(Contact* pc)
{
assert(pc);
if (pc->num == PEOPLE_MAX)
{
printf("通讯录已满,无法增加\n");
}
//没满,增加信息
printf("请输入名字:");
scanf("%s", pc->data[pc->num].name);//pc所指向的通讯录中下标为num的位置,将名字放入name成员中去
printf("请输入年龄:");
scanf("%d", &(pc->data[pc->num].age));//age是变量,需要&
printf("请输入性别:");
scanf("%s", pc->data[pc->num].sex);//sex是数组名,不需要&
printf("请输入电话:");
scanf("%s", pc->data[pc->num].tele);
printf("请输入地址:");
scanf("%s", pc->data[pc->num].addr);
pc->num++;
printf("添加成功!\n");
}
(3)显示联系人
void ShowContact(Contact* pc)
{
assert(pc);
if (pc->num == 0)
{
printf("通讯录为空,无需打印\n");
return;
}
int i = 0;
//名字 年龄 性别 电话 地址
//xxx xxx xxx xxx xxx
printf("%-20s%-5s%-5s%-12s%-30s\n", "名字", "年龄", "性别", "电话", "地址");//采用左对齐
for (i = 0; i < pc->num; i++)
{
//打印每个人的信息
printf("%-20s%-5d%-5s%-12s%-30s\n",
pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr);
}
}
(4)删除联系人
- 删除的方式
int FindByName(Contact* pc, char name[])
{
assert(pc);
//遍历数组查找
int i = 0;
for (i = 0; i < pc->num; i++)//找到返回下标,找不到返回 - 1
{
if (strcmp(pc->data[i].name, name) == 0)
{
return i;
}
}
return -1;
}
void DelContact(Contact* pc)
{
assert(pc);
char name[NAME_MAX];
if (pc->num == 0)
{
printf("通讯录为空,无法进行删除\n");
return;
}
printf("输入要删除的人的名字:");
scanf("%s", name);
//找到要删除的联系人
int ret = FindByName(pc, name);//分装查找函数
if (ret == -1)
{
printf("要删除的人不存在\n");
}
//删除此人
int i = 0;
for (i = ret; i <pc->num-1 ; i++)
{
pc->data[i] = pc->data[i + 1];
}
pc->num--;
printf("删除成功\n");
}
(5)查找某人
void SearchContact(Contact* pc)
{
assert(pc);
char name[NAME_MAX];
printf("请输入查找人的名字:");
scanf("%s", name);
int ret = FindByName(pc, name);//查找函数
if (ret == -1)
{
printf("要查找的人不存在\n");
}
//显示该人信息
printf("%-20s%-5s%-5s%-12s%-30s\n", "名字", "年龄", "性别", "电话", "地址");
printf("%-20s%-5d%-5s%-12s%-30s\n",
pc->data[ret].name, pc->data[ret].age, pc->data[ret].sex, pc->data[ret].tele, pc->data[ret].addr);
}
(6)修改指定联系人
void ModifyContact(Contact* pc)
{
char name[NAME_MAX];
assert(pc);
printf("请输入要修改人的名字:");
scanf("%s", name);
int ret = FindByName(pc, name);
if (ret == -1)
{
printf("要修改的人不存在\n");
return;
}
//修改
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");
}
(7)按照姓名首字母对联系人进行排序
- qsort函数
int cmp_name(const void* e1, const void* e2)
{
return strcmp(((PeoInfo*)e1)->name,((PeoInfo*)e2)->name);
}
void SortContact(Contact* pc)
{
assert(pc);
qsort(pc->data, pc->num, sizeof(PeoInfo), cmp_name);
printf("排序成功!\n");
}
四.完整代码
- 头文件类(contact.h)
//相关结构或者函数的声明
#include <stdio.h>
#include <assert.h>
#include <string.h>
#define NAME_MAX 20
#define SEX_MAX 5
#define TELE_MAX 12
#define ADDR_MAX 20
#define PEOPLE_MAX 100
typedef struct PeoInfo
{
char name[NAME_MAX];
int age;
char sex[SEX_MAX];
char tele[TELE_MAX];
char addr[ADDR_MAX];
}PeoInfo;//进行类型重命名,方便书写
typedef struct Contact
{
PeoInfo data[PEOPLE_MAX];//data数组用来存放100个人的信息
int num;//记录当前通讯录中已经存放的人的信息的个数
}Contact;
//通讯录初始化
void InitContact(Contact* pc);
//增加联系人
void AddContact(Contact* pc);
//显示所有的联系人
void ShowContact(Contact* pc);
//删除指定联系人
void DelContact(Contact*pc);
//查找指定联系人
void SearchContact(Contact* pc);
//修改指定联系人
void ModifyContact(Contact* pc);
//将联系人进行排序
void SortContact(Contact* pc);
- 功能实现类(contact.c)
//相关功能的实现
#include "contact.h"
//通讯录的初始化
void InitContact(Contact* pc)
{
assert(pc);
pc->num = 0;
memset(pc->data, 0, sizeof(pc->data));//将整个数组初始化为0
}
//增加联系人
void AddContact(Contact* pc)
{
assert(pc);
if (pc->num == PEOPLE_MAX)
{
printf("通讯录已满,无法增加\n");
return;
}
//没满,增加信息
printf("请输入名字:");
scanf("%s", pc->data[pc->num].name);//pc所指向的通讯录中下标为num的位置,将名字放入name成员中去
printf("请输入年龄:");
scanf("%d", &(pc->data[pc->num].age));//age是变量,需要&
printf("请输入性别:");
scanf("%s", pc->data[pc->num].sex);//sex是数组名,不需要&
printf("请输入电话:");
scanf("%s", pc->data[pc->num].tele);
printf("请输入地址:");
scanf("%s", pc->data[pc->num].addr);
pc->num++;
printf("添加成功!\n");
}
//显示所有的联系人
void ShowContact(Contact* pc)
{
assert(pc);
if (pc->num == 0)
{
printf("通讯录为空,无需打印\n");
return;
}
int i = 0;
//名字 年龄 性别 电话 地址
//xxx xxx xxx xxx xxx
printf("%-20s%-5s%-5s%-12s%-30s\n", "名字", "年龄", "性别", "电话", "地址");//采用左对齐
for (i = 0; i < pc->num; i++)
{
//打印每个人的信息
printf("%-20s%-5d%-5s%-12s%-30s\n",
pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr);
}
}
//删除联系人
int FindByName(Contact* pc, char name[])
{
assert(pc);
//遍历数组查找
int i = 0;
for (i = 0; i < pc->num; i++)//找到返回下标,找不到返回 - 1
{
if (strcmp(pc->data[i].name, name) == 0)
{
return i;
}
}
return -1;
}
void DelContact(Contact* pc)
{
assert(pc);
char name[NAME_MAX];
if (pc->num == 0)
{
printf("通讯录为空,无法进行删除\n");
return;
}
printf("输入要删除的人的名字:");
scanf("%s", name);
//找到要删除的联系人
int ret = FindByName(pc, name);//分装查找函数
if (ret == -1)
{
printf("要删除的人不存在\n");
}
//删除此人
int i = 0;
for (i = ret; i <pc->num-1 ; i++)
{
pc->data[i] = pc->data[i + 1];
}
pc->num--;
printf("删除成功\n");
}
//查找指定联系人
void SearchContact(Contact* pc)
{
assert(pc);
char name[NAME_MAX];
printf("请输入查找人的名字:");
scanf("%s", name);
int ret = FindByName(pc, name);//查找函数
if (ret == -1)
{
printf("要查找的人不存在\n");
}
//显示该人信息
printf("%-20s%-5s%-5s%-12s%-30s\n", "名字", "年龄", "性别", "电话", "地址");
printf("%-20s%-5d%-5s%-12s%-30s\n",
pc->data[ret].name, pc->data[ret].age, pc->data[ret].sex, pc->data[ret].tele, pc->data[ret].addr);
}
//修改指定联系人
void ModifyContact(Contact* pc)
{
char name[NAME_MAX];
assert(pc);
printf("请输入要修改人的名字:");
scanf("%s", name);
int ret = FindByName(pc, name);
if (ret == -1)
{
printf("要修改的人不存在\n");
return;
}
//修改
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");
}
//按照姓名排序联系人
int cmp_name(const void* e1, const void* e2)
{
return strcmp(((PeoInfo*)e1)->name,((PeoInfo*)e2)->name);
}
void SortContact(Contact* pc)
{
assert(pc);
qsort(pc->data, pc->num, sizeof(PeoInfo), cmp_name);
printf("排序成功!\n");
}
- 测试通讯录功能(test.c)
//用来测试通讯录的基本功能
#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");
}
enum Option
{
EXIT,//0
ADD,
DEL,
SEARCH,
MODIFY,
SHOW,
SORT
};
int main()
{
int input = 0;
//创建通讯录
Contact con;
//初始化通讯录
InitContact(&con);
do
{
menu();
printf("请选择:>\n");
scanf("%d", &input);
switch (input)
{
case ADD:
AddContact(&con);
break;
case DEL:
DelContact(&con);
break;
case SEARCH:
SearchContact(&con);
break;
case MODIFY:
ModifyContact(&con);
break;
case SHOW:
ShowContact(&con);
break;
case SORT:
SortContact(&con);
break;
case EXIT:
printf("退出通讯录\n");
break;
default:
printf("选择错误,请重新选择!\n");
break;
}
} while (input);
return 0;
}
总结:至此通讯录就创建完了,但受制于数据存放和存储信息大小等因素,后续还会更新