目录
一、动态通讯录
动态通讯录由三个板块构成;头文件,主函数,附加模块。
实现功能:存储联系人信息
缺陷:退出编译器通讯录自动清除
二、动态通讯录的实现
1.contact.h
#pragma once //防止头文件多次包含
#include<stdio.h>
#include<string.h>
#include<assert.h>
#include<stdlib.h>
#include<errno.h>
#pragma warning(disable:6031) //清除对scanf返回值的报警
#pragma warning(disable:4996) //使用低版本函数
#define MAX 100
#define MAX_ADDR 100
#define MAX_TELE 12
#define MAX_SEX 10
#define MAX_NAME 20
#define DEFAULT_SZ 3
#define INC_SZ 2
enum Option
{
EXIT,
ADD,
DEL,
SEARCH,
MODIFY,
SHOW,
SORT
};
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;
int count; //现有联系人数量
int capacity; //现可容纳联系人数量
}Contact; //定义一个通讯录的属性
extern void menu(void); //菜单函数
extern void InitContact(Contact*); //初始化函数
extern void AddContact(Contact*); //增加联系人函数
extern void ShowContact(const Contact*); //展示联系人函数
extern void DelContact(Contact*); //删除联系人函数
extern void SearchContact(const Contact*); //查找联系人函数
extern void ModifyContact(Contact*); //修改联系人函数
extern void DestoryContact(Contact*); //数据清除函数
extern void SortContact(Contact*); //排序联系人函数
2.test.c
#include"contact.h"
int main(void)
{
int input;
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:
DestoryContact(&con);
printf("退出\n");
break;
default:
printf("选择错误,请重新选择>:\n");
break;
}
} while (input);
return 0;
}
3.contact.c
#include"contact.h"
void menu(void)
{
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");
}
void InitContact(Contact* pc)
{
assert(pc);
pc->count = 0;
pc->data = (PeoInfo*)calloc(3, sizeof(PeoInfo));
if (pc->data == NULL)
{
printf("%s\n", strerror(errno));
exit(EXIT_FAILURE);
}
pc->capacity = DEFAULT_SZ;
}
void CheckCapacity(Contact* pc)
{
if (pc->count == pc->capacity)
{
PeoInfo* ptr = (PeoInfo*)realloc(pc->data, (pc->capacity + INC_SZ) * sizeof(PeoInfo));
if (ptr == NULL)
{
printf("%s\n", strerror(errno));
exit(EXIT_FAILURE);
}
else
{
pc->data = ptr;
pc->capacity += INC_SZ;
}
}
}
void AddContact(Contact* pc)
{
assert(pc);
CheckCapacity(pc);
printf("请输入名字>:");
scanf("%s", pc->data[pc->count].name);
printf("请输入年龄>:");
scanf("%d", &pc->data[pc->count].age);
printf("请输入性别>:");
scanf("%s", pc->data[pc->count].sex);
printf("请输入电话>:");
scanf("%s", pc->data[pc->count].tele);
printf("请输入地址>:");
scanf("%s", pc->data[pc->count].addr);
pc->count++;
printf("增加成功\n");
}
void ShowContact(const Contact* pc)
{
assert(pc);
if (!pc->count)
{
printf("通讯录为空\n");
return;
}
int i;
printf("%-20s\t%-5s\t%-5s\t%-12s\t%-5s\n", "名字", "年龄", "性别", "电话", "地址");
for (i = 0; i < pc->count; i++)
{
printf("%-20s\t%-5d\t%-5s\t%-12s\t%-5s\n",
pc->data[i].name, pc->data[i].age,
pc->data[i].sex, pc->data[i].tele, pc->data[i].addr);
}
}
static int FindByName(const Contact* pc, char name[])
{
assert(pc);
int i;
for (i = 0; i < pc->count; i++)
{
if (!strcmp(pc->data[i].name, name))
{
return i;
}
}
return -1;
}
void DelContact(Contact* pc)
{
assert(pc);
int pos,i;
char name[MAX_NAME];
if (!pc->count)
{
printf("通讯录为空\n");
return;
}
printf("请输入要删除人的名字:>");
scanf("%s", name);
if ((pos = FindByName(pc, name))==-1)
{
printf("找不到\n");
return;
}
for (i = pos; i < pc->count-1; i++)
{
pc->data[i] = pc->data[i + 1];
}
pc->count--;
printf("删除成功\n");
}
void SearchContact(const Contact* pc)
{
assert(pc);
char name[MAX_NAME];
int pos;
if (!pc->count)
{
printf("通信录为空\n");
return;
}
printf("请输入查找人姓名:>");
scanf("%s", name);
if ((pos = FindByName(pc, name))==-1)
{
printf("找不到\n");
return;
}
printf("%-20s\t%-5d\t%-5s\t%-12s\t%-5s\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];
int pos;
if (!pc->count)
{
printf("通信录为空,无联系人可修改\n");
return;
}
printf("请输入要修改联系人姓名:>");
scanf("%s", name);
if (!(pos = FindByName(pc, name)))
{
printf("要修改的联系人不存在\n");
return;
}
printf("请输入修改后的信息:>\n");
printf("请输入名字>:");
scanf("%s", pc->data[pos].name);
printf("请输入年龄>:");
scanf("%d", &pc->data[pos].age);
printf("请输入性别>:");
scanf("%s", pc->data[pos].sex);
printf("请输入电话>:");
scanf("%s", pc->data[pos].tele);
printf("请输入地址>:");
scanf("%s", pc->data[pos].addr);
printf("修改成功\n");
}
void DestoryContact(Contact* pc)
{
assert(pc);
free(pc->data);
pc->data = NULL;
}
int Cmp_name(const void* e1, const void* e2)
{
return strcmp(((PeoInfo*)e1)->name, ((PeoInfo*)e2)->name);
}
int Cmp_age(const void* e1, const void* e2)
{
return ((PeoInfo*)e1)->age - ((PeoInfo*)e2)->age;
}
int Cmp_sex(const void* e1, const void* e2)
{
return strcmp(((PeoInfo*)e1)->sex, ((PeoInfo*)e2)->sex);
}
int Cmp_tele(const void* e1, const void* e2)
{
return strcmp(((PeoInfo*)e1)->tele, ((PeoInfo*)e2)->tele);
}
int Cmp_addr(const void* e1, const void* e2)
{
return strcmp(((PeoInfo*)e1)->addr, ((PeoInfo*)e2)->addr);
}
void SortContact(Contact* pc)
{
assert(pc);
int input;
int (*arr[])(const void*, const void*) = { Cmp_name,Cmp_age ,Cmp_sex,Cmp_tele,Cmp_addr };
if (!pc->count)
{
printf("通信录为空,无联系人可排序\n");
return;
}
printf("请选择排序模式:> 0.姓名 1.年龄 2.性别 3.电话 4.地址\n");
while (1)
{
scanf("%d", &input);
if (input < 4 && input>0)
{
qsort(pc->data, pc->count, sizeof(PeoInfo), arr[input]);
printf("排序成功\n");
return;
}
else
{
printf("选择错误,请重新选择>:\n");
}
}
}