contact.h
#pragma once #include <string.h> #include <stdio.h> #include <assert.h> #include <stdlib.h> #define MAX 1000 #define NAME_MAX 20 #define SEX_MAX 5 #define SEX_MAX 12 #define ADDR_MAX 30 //通讯录初始状态的容量大小 #define DEFAULT_SZ 3 //类型的声明 typedef struct PeoInfo // 一个人的信息 { char name[NAME_MAX]; char sex[SEX_MAX]; int age; char tele[SEX_MAX]; char addr[ADDR_MAX]; }PeoInfo; enum Option //选则 { EXIT, //0 ADD, //1 DEL, //2 SEARCH, MODIFY, SORT, PRINT }; //静态版本 //typedef struct Contact //{ // PeoInfo data[1000]; // int sz; //记录已经保存的信息个数 // //}Contact; //动态版本 typedef struct Contact { PeoInfo* data; int sz; //记录已经保存的信息个数 int capacity; //记录通讯录当前最大容量 }Contact; // 函数的声明 //通讯录初始化 void InitContact(Contact* pc); //添加联系人信息 改变con void AddContact(Contact* pc); //打印信息 void PrintContact(const Contact* pc); //不希望修改 // 删除指定联系人 void DelContact(const Contact* pc); //查找联系人 void SearchContact(const Contact* pc); //销毁通讯录 void DestroyContact(const Contact* pc);
contact.c
#define _CRT_SECURE_NO_WARNINGS 1 #include "contact.h" //找到返回下标 找不到返回负一 int FindByName(const Contact* pc, char name[]) { assert(pc); int i = 0; for (i = 0; i < pc->sz; i++) { if (0 == strcmp(pc->data[i].name, name)) //用 strcmp 比较 相等返回下标 { return i; } } return -1; } //静态版本 //void InitContact(Contact* pc) //{ // assert(pc); //因为我们要用很多次指针所以要 断言一下 // pc->sz = 0; // memset(pc->data, 0, sizeof(pc->data) ); //data初始化 data全整成零 // //} //动态版本 void InitContact(Contact* pc) { assert(pc); //因为我们要用很多次指针所以要 断言一下 pc->sz = 0; pc->capacity = DEFAULT_SZ; pc->data = (PeoInfo*)malloc(pc->capacity * sizeof(PeoInfo)); if (pc->data == NULL) { perror("InitContact::malloc"); return 1; } memset(pc->data, 0, pc->capacity * sizeof(PeoInfo)); } void CheckCapacity(Contact* pc) { if (pc->capacity == pc->data) { PeoInfo* tmp = (PeoInfo*)realloc(pc->data, (pc->capacity + 2) * sizeof(PeoInfo)); if (tmp != NULL) { pc->data = tmp; } else { perror("CheckCapacity::realloc"); return; } } pc->capacity += 2; printf("\n增容成功!\n"); } void DestroyContact(Contact* pc) { free(pc->data); pc->data = NULL; pc->capacity = 0; pc->sz = 0; printf("销毁成功!"); } void AddContact(Contact* pc) { assert(pc); //静态版本 //if (pc->sz == MAX) //{ // printf("通讯录以满,无法添加\n"); // return; //} //动态版本 //增容代码 CheckCapacity(pc); // 录入信息 利用sz 与 data 的下标关系 printf("请输入名字:>"); scanf("%s", pc->data[pc->sz].name); printf("请输入年龄:>"); scanf("%d", &(pc->data[pc->sz].age)); // 注意加& printf("请输入电话:>"); scanf("%d", pc->data[pc->sz].tele); printf("请输入地址:>"); scanf("%s", pc->data[pc->sz].addr); pc->sz++; //利用sz 与 data 的下标关系 0对应data下标1,1对应data下标2 printf("添加成功\n"); } void PrintContact(const Contact* pc) //不希望修改 { assert(pc); printf("%-20s%-5s%-5s%-12s%-30s\n", "姓名", "年龄", "性别", "电话", "地址"); int i = 0; for (i = 0; i < pc->sz; i++) { printf("%-20s%-5d%-5s%-12s%-30s\n", pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr); } //左对齐加符号 } void DelContact(Contact* pc) { assert(pc); if (pc->sz == 0) { printf("通讯录已空,无法删除\n"); return; } //删除 //1. 找到 char name[NAME_MAX] = { 0 }; printf("请输入要删除人的名字:>"); scanf("%s", name); int pos = FindByName(pc, name); if (pos == -1) { printf("要删除的人不存在\n"); return; } //2. 删除 依次往前覆盖 int j = 0; for (j = pos; j < pc->sz - 1; j++) { pc->data[j] = pc->data[j + 1]; } pc->sz--; printf("删除成功\n"); } void SearchContact(const Contact* pc) { char name[NAME_MAX] = { 0 }; printf("请输入要查找人的名字:>"); scanf("%s", name); int pos = FindByName(pc, name); if (pos == -1) { printf("要查找的人不存在\n"); return; } printf("%-20s %-5s %-5s %-12s %-30s\n", "姓名", "年龄", "性别", "电话", "地址"); printf("%-20s %-5d %-5s %-12s %-30s\n", pc->data[pos].name, pc->data[pos].age, pc->data[pos].sex, pc->data[pos].tele, pc->data[pos].addr); }
test.c
#define _CRT_SECURE_NO_WARNINGS 1 #include "contact.h" //1.保存 1000 人联系人信息 //2.增添,删除联系人 //3.修改联系人 //4.查找联系人 //5.排序联系人 void menu() { printf("******************************\n"); printf("****** 1.Add 2.del ****\n"); printf("****** 3.search 4.moidfy ****\n"); printf("****** 5.sort 6.print ****\n"); printf("****** 0.exit ****\n"); } void test() { int input = 0; //创建通讯录 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: break; case SORT: break; case PRINT: PrintContact(&con); break; case EXIT: printf("退出通讯录\n"); void DestroyContact(const Contact * pc) break; default: printf("选择错误\n"); } } while (input); } int main(input) { test(); return 0; }