目录
预处理
菜单打印
代码整体框架
查找函数的分装
存放100个用户信息(名字,电话,性别,地址,年龄)
初始化通讯录
增加好友信息
删除好友信息
查找好友信息
修改好友信息
打印好友信息
按名字排序好友信息
最终效果
#include
#include
#include
#define MAX 1000
#define MAX_NAME 20
#define MAX_SEX 5
#define MAX_TELE 12
#define MAX_ADDR 30
enum Option
{
EXIT,//0
ADD,//1
DEL,//2
SEARCH,//3
MODIFY,//4
SHOW,//5
SORT//6
};
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()
{
int input = 0;
//创建通讯录
struct 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");
}
} while(input);
return 0;
}
static int FindByName(const struct Contact* ps, char name[MAX_NAME])//查找函数
{
int i = 0;
for (i = 0; i < ps->size; i++)
{
if (0 == strcmp(ps->data[i].name, name))
{
return i;
}
}
return -1;
}
struct PeoiInfor //每个用户的信息
{
char name[MAX_NAME];
int age;
char sex[MAX_SEX];
char tele[MAX_TELE];
char addr[MAX_ADDR];
};
struct Contact
{
struct PeoiInfor data[MAX]; //可存放1000个用户信息的数组
int size;
};
//初始化通讯录(全设置为零)
void InitContact(struct Contact* ps)
{
memset(ps->data, 0, sizeof(ps->data));
ps->size = 0;
}
void AddContact(struct Contact* ps)
{
if (ps->size == MAX)
{
printf("通讯录已满,无法增加\n");
}
else
{
printf("请输入名字:");
scanf("%s", ps->data[ps->size].name);
printf("请输入年龄:");
scanf("%d", &(ps->data[ps->size].age));
printf("请输入性别:");
scanf("%s", ps->data[ps->size].sex);
printf("请输入电话:");
scanf("%s", ps->data[ps->size].tele);
printf("请输入地址:");
scanf("%s", ps->data[ps->size].addr);
ps->size++;
printf("用户添加成功\n");
}
}
void DelContact(struct Contact* ps)
{
char name[MAX_NAME];
printf("请输入要删除人的名字\n");
scanf("%s", &name);
//1.查找要删除的人在什么位置
int pos= FindByName(ps, name);//找到了返回下标,找不到返回-1.
if (pos == -1)
{
printf("要删除的人不存在\n");
}
else
{
//删除数据
int j = 0;
for (j = 0; j < (ps->size - 1); j++)
{
ps->data[j] = ps->data[j + 1];
}
ps->size--;
printf("删除成功\n");
}
}
void SearchContact(const struct Contact* ps)
{
printf("请输入要查找人的名字\n");
char name[MAX_NAME];
scanf("%s", &name);
int i=FindByName(ps, name);
if (i == -1)
{
printf("查无此人\n");
}
else
{
printf("%-20s\t%-4s\t%-5s\t%-12s\t%-20s\n", "名字", "年龄", "性别", "电话", "地址");
printf("%-20s\t%-4d\t%-5s\t%-12s\t%-20s\n",
ps->data[i].name,
ps->data[i].age,
ps->data[i].sex,
ps->data[i].tele,
ps->data[i].addr);
}
}
void ModifyContact(struct Contact* ps)
{
char name[MAX_NAME];
printf("请输入要修改人的名字:");
scanf("%s", name);
int pos = FindByName(ps, name);
if (pos == -1)
printf("要修改人的信息不存在\n");
else
{
printf("请输入名字:");
scanf("%s", ps->data[pos].name);
printf("请输入年龄:");
scanf("%d", &(ps->data[pos].age));
printf("请输入性别:");
scanf("%s", ps->data[pos].sex);
printf("请输入电话:");
scanf("%s", ps->data[pos].tele);
printf("请输入地址:");
scanf("%s", ps->data[pos].addr);
ps->size++;
printf("用户修改成功\n");
}
}
void ShowContact(const struct Contact* ps)
{
if (ps->size == 0)
printf("通讯录为空\n");
else
{
int i = 0;
//标题
printf("%-20s\t%-4s\t%-5s\t%-12s\t%-20s\n", "名字", "年龄", "性别", "电话", "地址");
for (i = 0; i < ps->size; i++)
{
printf("%-20s\t%-4d\t%-5s\t%-12s\t%-20s\n",
ps->data[i].name,
ps->data[i].age,
ps->data[i].sex,
ps->data[i].tele,
ps->data[i].addr);
}
}
}
int compar(const void* e1,const void* e2)
{
return strcmp(((struct PeoiInfor*)e1)->name, ((struct PeoiInfor*)e2)->name);
}
void SortContact(struct Contact *ps)
{
qsort(ps->data, ps->size, sizeof(ps->data[0]), compar);
if (ps->size == 0)
printf("通讯录为空\n");
else
{
int i = 0;
//标题
printf("%-20s\t%-4s\t%-5s\t%-12s\t%-20s\n", "名字", "年龄", "性别", "电话", "地址");
for (i = 0; i < ps->size; i++)
{
printf("%-20s\t%-4d\t%-5s\t%-12s\t%-20s\n",
ps->data[i].name,
ps->data[i].age,
ps->data[i].sex,
ps->data[i].tele,
ps->data[i].addr);
}
}
}