通讯录
本次创建的通讯录可以简单的实现增加、删除、查找、修改、查看、排序的功能。
首先会有一个菜单:
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");
}
接下来可以根据菜单选择你所需要的功能;
首先得先添加几个数据:比如选择1 ,添加一些文本在里面;
整个功能的实现主要如下:
int main()
{
int input = 0;
Contact con;
InitContact(&con);
do
{
menu();
printf("请输入选择:");
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;
}
ADD函数主要实现添加的功能,
void AddContact(Contact* pcon)
{
assert(pcon);
if (pcon->sz == MAX)
{
printf("通讯录已满,无法添加\n");
return;
}
printf("请输入姓名:\n");
scanf("%s", pcon->data[pcon->sz].name);
printf("请输入性别:\n");
scanf("%s", pcon->data[pcon->sz].sex);
printf("请输入年龄:\n");
scanf("%d", &pcon->data[pcon->sz].age);
printf("请输入电话:\n");
scanf("%s", pcon->data[pcon->sz].tele);
printf("请输入住址:\n");
scanf("%s", pcon->data[pcon->sz].addr);
pcon->sz++;
printf("录入成功\n");
}
比如我录入了两个内容:
5是展示通讯录内容;所以会看到我录入的内容;
DEL函数主要实现的是删除,主要代码如下,下图有实现成功的图片;
void DelContact(Contact* pcon)
{
int i = 0;
char name[NAME] = { 0 };
int pos = 0;
assert(pcon);
if (pcon->sz == 0)
{
printf("通讯录已空,无法删除\n");
return;
}
printf("请输入要删除人的名字:");
scanf("%s", name);
pos = FindByName(pcon, name);
if (pos == -1)
{
printf("要删除的不存在\n");
return;
}
for (i = pos; i < pcon->sz; i++)
{
pcon->data[i] = pcon->data[i + 1];
}
pcon->sz--;
printf("删除成功\n");
}
其中出现了FindByName函数,主要是通过查找姓名来帮助删除函数,在以后的很多功能中也会用到此函数;
static int FindByName(Contact* pcon, char name[])
{
int i = 0;
assert(pcon);
for (i = 0; i < pcon->sz; i++)
{
if (0 == strcmp(pcon->data[i].name, name))
{
return i;
}
}
return -1;
}
完成删除后我们要进行后续的一些功能的实现,我会随机的再多录几个内容进去;
接下来开始实现查找函数;
void SearchContact(const Contact* pcon)
{
int i = 0;
char name[NAME] = { 0 };
int pos = 0;
assert(pcon);
if (pcon->sz == 0)
{
printf("通讯录已空,无法查找\n");
return;
}
printf("请输入要查找人的名字:");
scanf("%s", name);
pos = FindByName(pcon, name);
if (pos == -1)
{
printf("要查找的不存在\n");
return;
}
printf("%15s\t%5s\t%5s\t%12s\t%20s\n", "姓名", "年龄", "性别", "电话", "住址");
printf("%15s\t%5d\t%5s\t%12s\t%20s\n", pcon->data[i].name,
pcon->data[i].age,
pcon->data[i].sex,
pcon->data[i].tele,
pcon->data[i].addr);
}
MODIFY函数是我创建的用来修改的函数,以下是相关代码及实现:
void ModifyContact(Contact *pcon)
{
int i = 0;
char name[NAME] = { 0 };
int pos = 0;
assert(pcon);
if (pcon->sz == 0)
{
printf("通讯录已空,无法修改\n");
return;
}
printf("请输入要修改人的名字:");
scanf("%s", name);
pos = FindByName(pcon, name);
printf("%15s\t%5s\t%5s\t%12s\t%20s\n", "姓名", "年龄", "性别", "电话", "住址");
printf("%15s\t%5d\t%5s\t%12s\t%20s\n", pcon->data[i].name,
pcon->data[i].age,
pcon->data[i].sex,
pcon->data[i].tele,
pcon->data[i].addr);
if (pos == -1)
{
printf("要修改的不存在\n");
return;
}
for (i = pos; i < pcon->sz; i++)
{
pcon->data[i] = pcon->data[i + 1];
}
pcon->sz--;
printf("请输入新姓名:\n");
scanf("%s", pcon->data[pcon->sz].name);
printf("请输入新性别:\n");
scanf("%s", pcon->data[pcon->sz].sex);
printf("请输入新年龄:\n");
scanf("%d", &pcon->data[pcon->sz].age);
printf("请输入新电话:\n");
scanf("%s", pcon->data[pcon->sz].tele);
printf("请输入新住址:\n");
scanf("%s", pcon->data[pcon->sz].addr);
pcon->sz++;
printf("修改成功\n");
}
Show函数在其他几个函数中都有实现,下面放一下代码就不再截图了;
void ShowContact(const Contact* pcon)
{
int i = 0;
assert(pcon);
printf("%15s\t%5s\t%5s\t%12s\t%20s\n", "姓名", "年龄", "性别", "电话", "住址");
for (i = 0; i < pcon->sz; i++)
{
printf("%15s\t%5d\t%5s\t%12s\t%20s\n", pcon->data[i].name,
pcon->data[i].age,
pcon->data[i].sex,
pcon->data[i].tele,
pcon->data[i].addr);
}
}
Sort函数是用来排序的函数,主要是通过姓名进行排序,但我的每一个数据都是用相同数字录入的,所以看起来不是很清楚,但可以执行是真的;
void SortContact(Contact* pcon)
{
int i = 0;
assert(pcon);
for (i = 0; i < pcon->sz - 1; i++)
{
int flag = 1;
int j = 0;
for (j = 0; j < pcon->sz - i - 1; j++)
{
if (strcmp(pcon->data[j].name, pcon->data[j + 1].name)>0)
{
PeoInfo tmp = pcon->data[j];
pcon->data[j] = pcon->data[j + 1];
pcon->data[j + 1] = tmp;
flag = 0;
}
}
if (flag == 1)
break;
}
}
可以看到排序成功了;
其实在整个过程中有很多函数在执行前都对通讯录的内容有所判断,比如DEL删除函数、SEARCH查找函数、MODIFY修改函数等都对通讯录里是否有数据进行了判断,我并没有一一实现。
在整个代码中,基本上都是用指针完成的,所以要对指针有多了解。其实在过程中也遇到了一些问题,比如对指针的运用还不是很成熟,有时就会对取地址的问题搞混,但总归是不能放弃的。
由于代码中运用的函数较多,所以我创建了一个头文件,专门放用到的头文件。
#define _CRT_SECURE_NO_WARNINGS 1
#define _CRT_SECURE_NO_WARNINGS 1
#define MAX 1000
#define NAME 20
#define SEX 5
#define TELE 12
#define ADDR 25
#define DEFAULT_SZ 2
#include <stdio.h>
#include <assert.h>
#include <string.h>
#include <stdlib.h>
#include <errno.h>
enum Option
{
EXIT,
ADD,
DEL,
SEARCH,
MODIFY,
SHOW,
SORT
};
typedef struct PeoInfo
{
char name[NAME];
char sex[SEX];
short age;
char tele[TELE];
char addr[ADDR];
}PeoInfo;
typedef struct Contact
{
struct PeoInfo* data;
int sz;//记录当前有多少人的信息
}Contact;
void InitContact(Contact* pcon);
void AddContact(Contact* pcon);
void DelContact(Contact* pcon);
void ShowContact(const Contact* pcon);
int FindByName(Contact* pcon, char name[]);
void ModifyContact(Contact *pcon);
void SearchContact(const Contact* pcon);
void SortContact(Contact* pcon);
要完成一个通讯录简单的实现基本就是这个样子,后续我还会继续学习,不断改善这个通讯录的实现。