目录
预处理
#include<stdio.h> #include<string.h> #include<stdlib.h> #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; }
存放100个用户信息(名字,电话,性别,地址,年龄)
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); } } }
最终效果