动态实现一个通讯录
通讯录可以用来存储1000个人的信息,每个人的信息包括:姓名、性别、年龄、电话、住址
提供方法:
- 添加联系人信息
- 删除指定联系人信息
- 查找指定联系人信息
- 修改指定联系人信息
- 显示所有联系人信息
- 清空所有联系人
以名字排序所有联系人
宏定义,结构体定义以及函数声明
头文件contact.h
#ifndef _CONTACT_H_
#define _CONTACT_H_
#include<stdio.h>
#include<assert.h>
#include<string.h>
//定义操作选项
typedef enum
{
QUIT,
ADD,
DEL,
FIND,
MODIFY,
SHOW,
CLEAR,
SORT
}OPER_ENUM;
//#define MAX_CONTACT_SIZE 1000
#define DEFAULT_CONTACT_SIZE 2
#define MAX_NAME_SIZE 20
#define MAX_ADDR_SIZE 256
//定义人员信息结构
typedef struct PersonInfo
{
char name[MAX_NAME_SIZE];
char sex[3];
char tel[12];
char addr[MAX_ADDR_SIZE];
int age;
}personinfo;
//定义通讯录结构
typedef struct contact
{
//personinfo data[MAX_CONTACT_SIZE];
personinfo *data;
size_t size;
size_t capacity;
}contact;
//函数声明
void InitContact(contact *pct);
void AddContact(contact *pct);
void ShowContact(contact *pct);
void FindContact(contact *pct);
void DelContact(contact *pct);
void ModifyContact(contact *pct);
void ClearContact(contact *pct);
void SortContact(contact *pct);
void DestroyContact(contact *pct);
void LoadContact(contact *pct);
void SaveContact(contact *pct);
#endif /* _CONTACT_H_ */
功能函数
源文件contact.c
#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"
#include <stdlib.h>
void InitContact(contact *pct)
{
assert(pct != NULL);
pct->capacity = DEFAULT_CONTACT_SIZE;
pct->data = (personinfo*)malloc(sizeof(personinfo) * pct->capacity);
assert(pct->data != NULL);
memset(pct->data, 0, sizeof(personinfo) * pct->capacity);
pct->size = 0;
LoadContact(pct);//文件读取
static int FindByname(contact *pct, char *name)
{
for (size_t i = 0; i < pct->size; ++i)
{
if (strcmp(pct->data[i].name, name) == 0)
return i;
}
return -1;
}
static void CheckCapacity(contact *pct)
{
if (pct->size >= pct->capacity)
{
//空间满了
personinfo *new_data = (personinfo*)realloc(pct->data, sizeof(personinfo)*(pct->capacity * 2));
assert(new_data != NULL);
pct->capacity *= 2;
pct->data = new_data;
printf("扩容成功.....\n");
}
}
void AddContact(contact *pct)
{
assert(pct != NULL);
//检查容量
CheckCapacity(pct);
printf("姓名:>");
scanf("%s", pct->data[pct->size].name);
printf("性别:>");
scanf("%s", pct->data[pct->size].sex);
printf("年龄:>");
scanf("%d", &(pct->data[pct->size].age));
printf("电话:>");
scanf("%s", pct->data[pct->size].tel);
printf("住址:>");
scanf("%s", pct->data[pct->size].addr);
pct->size++;
printf("新增通讯录人员信息成功......\n");
}
void ShowContact(contact *pct)
{
assert(pct != NULL);
printf("**************************************************\n");
printf("*%-10s%-8s%-8s%-12s%-30s\n", "姓名", "性别", "年龄", "电话", "住址");
for (size_t i = 0; i < pct->size; ++i)
{
printf("*%-10s%-8s%-8d%-12s%-30s\n", pct->data[i].name,
pct->data[i].sex,
pct->data[i].age,
pct->data[i].tel,
pct->data[i].addr);
}
printf("**************************************************\n");
}
void FindContact(contact *pct)
{
assert(pct != NULL);
if (pct->size == 0)
{
printf("通讯录为空,不能查询.....\n");
return;
}
char name[MAX_NAME_SIZE] = { 0 };
printf("请输入要查询的名字:>");
scanf("%s", name);
int index = FindByname(pct, name);
if (index == -1)
{
printf("查无此人.....\n");
return;
}
printf("*%-10s%-8s%-8s%-12s%-30s\n", "姓名", "性别", "年龄", "电话", "住址");
printf("*%-10s%-8s%-8d%-12s%-30s\n", pct->data[index].name,
pct->data[index].sex,
pct->data[index].age,
pct->data[index].tel,
pct->data[index].addr);
}
void DelContact(contact *pct)
{
assert(pct != NULL);
if (pct->size == 0)
{
printf("通讯录为空,不能删除.....\n");
return;
}
char name[MAX_NAME_SIZE] = { 0 };
printf("请输入要删除的名字:>");
scanf("%s", name);
int index = FindByname(pct, name);
if (index == -1)
{
printf("要删除的人不存在.....\n");
return;
}
for (unsigned int i = index; i < pct->size; ++i)
pct->data[i] = pct->data[i + 1];
pct->size--;
printf("删除成功......\n");
}
void ModifyContact(contact *pct)
{
assert(pct != NULL);
if (pct->size == 0)
{
printf("通讯录为空,不能修改.....\n");
return;
}
char name[MAX_NAME_SIZE] = { 0 };
printf("请输入要修改的名字:>");
scanf("%s", name);
int index = FindByname(pct, name);
if (index == -1)
{
printf("要修改的人不存在.....\n");
return;
}
int select = 1;
while (select)
{
printf("你想修改什么信息(1-姓名 2-性别 3-年龄 4-电话 5-住址)\n");
scanf("%d", &select);
switch (select)
{
case 1:
printf("请输入要修改的姓名:>");
scanf("%s", pct->data[index].name);
break;
case 2:
printf("请输入要修改的性别:>");
scanf("%s", pct->data[index].sex);
break;
case 3:
printf("请输入要修改的年龄:>");
scanf("%d", &(pct->data[index].age));
break;
case 4:
printf("请输入要修改的电话:>");
scanf("%s", pct->data[index].tel);
break;
case 5:
printf("请输入要修改的住址:>");
scanf("%s", pct->data[index].addr);
break;
default:
printf("修改选项出错,请重新选择.\n");
continue;
}
break;
}
printf("修改成功......\n");
}
void ClearContact(contact *pct)
{
printf("确定要清空通讯录吗?<y/n> :>");
char ch;
fflush(stdin); //清空缓冲区里的\n
scanf("%c", &ch);
if (ch == 'n' || ch == 'n')
return;
pct->size = 0;
memset(pct->data, 0, sizeof(pct->data));
}
void SortContact(contact *pct)
{
for (unsigned int i = 0; i < pct->size - 1; ++i)
{
for (unsigned int j = 0; j < pct->size - i - 1; ++j)
{
if (strcmp(pct->data[j].name, pct->data[j + 1].name) > 0)
{
personinfo tmp = pct->data[j];
pct->data[j] = pct->data[j + 1];
pct->data[j + 1] = tmp;
}
}
}
printf("排序成功.....\n");
}
void DestroyContact(contact *pct)
{
free(pct->data);
pct->data = NULL;
pct->capacity = pct->size = 0;
printf("数据清理成功.....\n");
}
void SaveContact(contact *pct)
{
FILE *fp = fopen("contact.dat", "w");
assert(fp != NULL);
for (size_t index = 0; index < pct->size; ++index)
{
fprintf(fp, "%-10s%-8s%-8d%-12s%-30s\n", pct->data[index].name,
pct->data[index].sex,
pct->data[index].age,
pct->data[index].tel,
pct->data[index].addr);
}
fclose(fp);
printf("通讯录保存成功.....\n");
}
void LoadContact(contact *pct)
{
FILE *fp = fopen("contact.dat", "r");
assert(fp != NULL);
while (feof(fp) != EOF)
{
CheckCapacity(pct);
int res = fscanf(fp, "%s %s %d %s %s", pct->data[pct->size].name,
pct->data[pct->size].sex,
&(pct->data[pct->size].age),
pct->data[pct->size].tel,
pct->data[pct->size].addr);
if (res == EOF) //达到了文件末尾
break;
pct->size++;
}
fclose(fp);
printf("加载通讯录成功.....\n");
}
主函数
源文件contact_main.c
#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"
void Menu()
{
printf("*************通讯录**************\n");
printf("* [1] Add [2] Del *\n");
printf("* [3] Find [4] Modify*\n");
printf("* [5] Show [6] Clear *\n");
printf("* [7] Sort [0] Quit *\n");
printf("*********************************\n");
}
int main(int argc, char *argv[])
{
contact cont; //定义通讯录变量
InitContact(&cont);
int select = 1;
while (select)
{
Menu();
printf("请选择:>");
scanf("%d", &select);
if (select == QUIT)
break;
switch (select)
{
case ADD:
AddContact(&cont);
break;
case DEL:
DelContact(&cont);
break;
case FIND:
FindContact(&cont);
break;
case MODIFY:
ModifyContact(&cont);
break;
case SHOW:
ShowContact(&cont);
break;
case CLEAR:
ClearContact(&cont);
break;
case SORT:
SortContact(&cont);
break;
default:
printf("输入选择错误,请重新输入...\n");
break;
}
}
SaveContact(&cont);
DestroyContact(&cont);
printf("退出通讯录系统,Good Bye......\n");
return 0;
}
资源文件contact.dat
simon 男 17 15466545 西安
lady 女 18 15466566 成都
Cindy 女 20 15466545 上海
candy 女 38 15466545 北京
gala 男 22 15466545 广州