头文件包含
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
#include<string.h>
#include<errno.h>
#define MAX 50
#define NAME_MAX 20
#define SEX_MAX 4
#define PHONE_MAX 20
#define ADDRESS_MAX 20
#define INC_SZ 2
#define DEFAULT 3
typedef struct peoinfo
{
char name[NAME_MAX];
char phone[PHONE_MAX];
char sex[SEX_MAX];
char address[ADDRESS_MAX];
}peoinfo;
typedef struct contact
{
peoinfo* data;
int count;
int capacity;
}contact;
int initcontact(contact* pc);
void addcontact(contact* pc);
int searchname(contact* pc, char name[]);
void delcontact(contact* pc);
void showcontact(contact* pc);
void sortcontact(contact* pc);
void modifycontact(contact* pc);
void searchcontact(contact* pc);
void breakcontact(contact* pc);
函数实现
#include "tools.h"
int initcontact(contact* pc)
{
assert(pc);
pc ->count = 0;
pc->data = (peoinfo*)calloc(DEFAULT, sizeof(peoinfo));
if (pc->data == NULL)
{
printf("%s\n", strerror(errno));
return 1;
}
pc -> capacity = DEFAULT;
return 0;
}
void checkcontact(contact* pc)
{
if (pc->count == pc->capacity)
{
peoinfo* ptr = (peoinfo*)realloc(pc->data, (pc->capacity + 2) * sizeof(peoinfo));
if (ptr == NULL)
{
printf("add%s", strerror(errno));
return;
}
else
{
pc->data = ptr;
pc->capacity += INC_SZ;
printf("增容成了\n");
}
}
}
void addcontact(contact* pc)
{
assert(pc);
checkcontact(pc);
printf("请输入名字\n");
scanf("%s", pc->data[pc->count].name);
printf("请输入电话号码\n");
scanf("%s", pc->data[pc->count].phone);
printf("请输入性别\n");
scanf("%s", pc->data[pc->count].sex);
printf("请输入家庭住址\n");
scanf("%s", pc->data[pc->count].address);
pc->count++;
printf("已添加成功\n");
}
int searchname(contact* pc, char name[])
{
assert(pc);
int i = 0;
for (i = 0; i < pc->count; i++)
{
if (0 == strcmp(pc->data[i].name, name))
{
return i;
}
}
return -1;
}
void delcontact(contact* pc)
{
char name[20] = { 0 };
assert(pc);
printf("请输入要删除谁的信息\n");
scanf("%s", name);
if (pc->count == 0)
{
printf("通讯录为空,无法删除\n");
return;
}
int k = searchname(pc, name);
if (k == -1)
{
printf("没有查找到此人信息,删除失败\n");
}
int i = 0;
for (i = k; i < pc->count - 1; i++)
{
pc->data[i] = pc->data[i + 1];
}
pc -> count--;
printf("删除成功了\n");
}
void showcontact(contact* pc)
{
assert(pc);
printf("%-20s\t%-20s\t%-4s\t%-20s\n", "姓名", "电话号码","性别", "家庭地址");
int i = 0;
for (i = 0; i < pc->count; i++)
{
printf("%-20s\t%-20s\t%-4s\t%-20s\n",
pc->data[i].name,
pc->data[i].phone,
pc->data[i].sex,
pc->data[i].address);
}
}
int cmp_by_name(const void* e1,const void* e2)
{
return strcmp((peoinfo*)e1,(peoinfo*)e2);
}
void sortcontact(contact* pc)
{
assert(pc);
if (pc->count <= 1)
{
printf("数据过少,无法排序\n");
}
qsort(pc->data, pc->count, sizeof(pc->data[0]), cmp_by_name);
printf("排序完成\n");
}
void searchcontact(contact* pc)
{
char name[20] = { 0 };
assert(pc);
printf("请输入你要查找的名字\n");
scanf("%s", name);
int k = searchname(pc, name);
if (k == -1)
{
printf("没有找到此人\n");
}
printf("找到了\n");
printf("%-20s\t%-20s\t%-4s\t%-20s\n", "姓名", "电话号码", "性别", "家庭地址");
printf("%-20s\t%-20s\t%-4s\t%-20s\n",
pc->data[k].name,
pc->data[k].phone,
pc->data[k].sex,
pc->data[k].address);
}
void modifycontact(contact* pc)
{
printf("请输入要修改的人的名字\n");
char name[20] = { 0 };
scanf("%s", name);
int i = searchname(pc, name);
if (i == -1)
{
printf("没有查找到这个人\n");
}
printf("查找到了请开始修改\n");
printf("请输入名字\n");
scanf("%s", pc->data[i].name);
printf("请输入电话号码\n");
scanf("%s", pc->data[i].phone);
printf("请输入性别\n");
scanf("%s", pc->data[i].sex);
printf("请输入家庭住址\n");
scanf("%s", pc->data[i].address);
printf("修改完成\n");
}
void breakcontact(contact* pc)
{
assert(pc);
free(pc->data);
pc->data = NULL;
}
主函数部分
#include<stdio.h>
#include"tools.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");
}
int main()
{
contact a;
initcontact(&a);
int input = 0;
do
{
menu();
printf("请输入数字\n");
scanf("%d", &input);
switch (input)
{
case 1:
addcontact(&a);
break;
case 2:
delcontact(&a);
break;
case 3:
searchcontact(&a);
break;
case 4:
modifycontact(&a);
break;
case 5:
showcontact(&a);
break;
case 6:
sortcontact(&a);
break;
case 0:
breakcontact(&a);
printf("退出通讯录\n");
default:
printf("输入错误重新输入\n");
}
}
while (input);
return 0;
}