目录
预处理
#pragma once #include<stdio.h> #include<string.h> #include<stdlib.h> #define DEFAULT_SZ 3 #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; int capacity;//当前通讯里的最大容量 int size;//记录当前已有元素的个数 };
初始化通讯录
void InitContact(struct Contact* ps) { ps->data =(struct PeoiInfor*) malloc(DEFAULT_SZ * sizeof(struct PeoiInfor)); if (ps->data == NULL) { return; } ps->capacity = DEFAULT_SZ; ps->size = 0; }
动态增加通讯录容量
void CheckCapacity(struct Contact* ps) { if (ps->size == ps->capacity) { struct PeoiInfor*ptr= realloc(ps->data, (ps->capacity + 2) * sizeof(struct PeoiInfor)); if (ptr != NULL) { ps->data = ptr; ps->capacity += 2; printf("增容成功\n"); } else printf("增容失败\n"); } }
增加好友信息
void AddContact(struct Contact* ps) { //检测当前通讯录的容量 //如果满了增加容量 CheckCapacity(ps); 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"); } }