1:contact.h头文件(不做文字描述,相关介绍均在注释中,用以各功能函数的声明)
#pragma once
#define NAME_MAX 50
#define SEX_MAX 10
#define MAX 1000
#define ADDR_MAX 50
#define TEL_MAX 20
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
//每个联系人的信息
struct PeopInfo
{
char name[NAME_MAX];
int age;
char tel[TEL_MAX];
char sex[SEX_MAX];
char addr[ADDR_MAX];
};
//创建一个结构体,让这个结构体可以包含容量为MAX个人的信息,即通讯录
struct contact
{
struct PeopInfo data[MAX];
int sz;
};
//初始化通讯录
void InitContact(struct contact* pc);
//添加联系人信息
void AddContact(struct contact* pc);
//展示通讯录
void ShowContact(struct contact* pc);
//删除联系人信息
void DelContact(struct contact* pc);
//查找联系人
void SearchContact(struct contact* pc);
//修改联系人信息
void ModifyContact(struct contact* pc);
//按照年龄进行排序
void SortByAge(struct contact* pc);
2.contact.c(通讯录各功能的定义)
#include "contact.h"
//初始化通讯录
void InitContact(struct contact* pc)
{
pc->sz = 0;
memset(pc->data, 0, sizeof(struct PeopInfo[MAX]));//全部置为0
}
//添加联系人信息
void AddContact(struct contact* pc)
{
//要先判断通讯录是否已满?
if (pc->sz != MAX)
{
//添加
printf("请输入联系人姓名:>");
scanf("%s", pc->data[pc->sz].name);
printf("请输入联系人的年龄:>");
scanf("%d", &(pc->data[pc->sz].age));
printf("请输入联系人的电话:>");
scanf("%s", pc->data[pc->sz].tel);
printf("请输入联系人的性别:>");
scanf("%s", pc->data[pc->sz].sex);
printf("请输入联系人的地址:>");
scanf("%s", pc->data[pc->sz].addr);
printf("添加完成!\n");
pc->sz++;//每添加一个人,有效信息个数就加一
}
else
{
printf("通讯录已满!\n");
return;
}
}
//展示通讯录
void ShowContact(struct contact* pc)
{
//先展示一个表头
printf("%-15s\t%5s\t%15s\t\t%5s\t%20s\n","姓名","年龄","电话","性别","地址");//姓名、年龄、电话、性别、地址
int i = 0;
for (i = 0; i < pc->sz; i++)
{
printf("%-15s\t%5d\t%15s\t\t%5s\t%20s\n", pc->data[i].name, pc->data[i].age, pc->data[i].tel, pc->data[i].sex, pc->data[i].addr);
}
}
//删除联系人信息
//查找联系人(依据联系人的姓名)
int FindByName(struct contact* pd,char* name)
{
//遍历式查找
int i = 0;
for (i = 0; i < pd->sz; i++)
{
if (strcmp(pd->data[i].name, name) == 0)
{
return i;
}
}
return -1;
}
void DelContact(struct contact* pc)
{
//通讯录为空肯定没法删除联系人
if (pc->sz == 0)
{
printf("通讯录为空,无法删除\n");
return;
}
else
{
//删除也要利用一个信息去找到那个人,然后再去把他删除,这里使用一个人的姓名
char name[NAME_MAX];
printf("请输入要删除的联系人的姓名:>");
scanf("%s", name);
int tmp=FindByName(pc,name);//靠姓名在通讯录中查找这个人
if (tmp == -1)
{
printf("查无此人\n");
}
else
{
//进行删除
//用后面人的信息覆盖要被删除联系人的信息
int j = 0;
for (j = tmp; j < pc->sz - 1; j++)
{
pc->data[j] = pc->data[j + 1];//这种操作注意一下,实现一个数组的覆盖
}
//覆盖完,通讯录的有效信息应当减一
pc->sz--;//这里其实可以保证只有一个联系人时,showcontact不会打印联系人信息,相当于删除了一个联系人
//而如果是检索到的是通讯录最后一个联系人的话,同理不会被打印,也相当于删除了一个联系人,其余均为一般情况
printf("联系人删除成功!\n");
}
}
}
//查找联系人
void SearchContact(struct contact* pc)
{
//这里依据姓名进行查找,其实和findbyname是一样的
char name[NAME_MAX];
printf("请输入你想要查找的联系人姓名:>");
scanf("%s", name);
int i = 0;
for (i = 0; i < pc->sz; i++)
{
if (strcmp(pc->data[i].name, name) == 0)
{
printf("%-15s\t%5s\t%15s\t\t%5s\t%20s\n", "姓名", "年龄", "电话", "性别", "地址");
printf("%-15s\t%5d\t%15s\t\t%5s\t%20s\n", pc->data[i].name, pc->data[i].age, pc->data[i].tel, pc->data[i].sex, pc->data[i].addr);
return;//找到了,直接结束查找函数即可
}
}
printf("查无此人\n");
}
//修改联系人信息
void ModifyContact(struct contact* pc)
{
//要修改联系人信息,就得先找到指定联系人,这里依旧依据姓名进行查找
char name[NAME_MAX];
printf("请输入需要修改信息人的姓名:>");
scanf("%s", name);
int tmp = FindByName(pc, name);
if (tmp == -1)
{
printf("查无此人\n");
return;
}
else
{
printf("请输入联系人姓名:>");
scanf("%s", pc->data[tmp].name);
printf("请输入联系人的年龄:>");
scanf("%d", &(pc->data[tmp].age));
printf("请输入联系人的电话:>");
scanf("%s", pc->data[tmp].tel);
printf("请输入联系人的性别:>");
scanf("%s", pc->data[tmp].sex);
printf("请输入联系人的地址:>");
scanf("%s", pc->data[tmp].addr);
printf("修改成功\n");
}
}
//按照年龄进行排序
int compare(const void* e1, const void* e2)
{
return *(int*)e1 - *(int*)e2;
}
void SortByAge(struct contact* pc)
{
//用之前学的qsort()函数:void qsort( void *base, size_t num, size_t width, int (__cdecl *compare )(const void *elem1, const void *elem2 ) );
qsort(pc->data, pc->sz, sizeof(pc->data[0]), compare);
printf("按年龄升序排序成功\n");
}
3.test.c(用以测试通讯录是否实现,相关介绍均在注释中)
#include <stdio.h>
#include "contact.h"
void menu()
{
printf("*****************************\n");
printf("*****0.exit 1.add ******\n");
printf("*****2.del 3.search******\n");
printf("*****4.modify 5.show ******\n");
printf("*****6.sort ******\n");
}
enum Option
{
EXIT,
ADD,
DEL,
SEARCH,
MODIFY,
SHOW,
SORT
};
int main()
{
//创建一个通讯录
struct contact con;
//对con进行初始化
InitContact(&con);
int input = 0;
do
{
menu();
printf("请输入你的选择:>");
scanf("%d", &input);
switch (input)
{
case EXIT:
printf("已退出通讯录\n");
break;
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:
SortByAge(&con);//顾名思义
break;
default:
printf("输入有误,请重新输入:>");
break;
}
} while (input);
return 0;
}