好网站建设公司收费,中国建设银行网站解绑手机,经典vi设计案例分析,多用户购物商城目录
一、设计框架
1、功能要求
2、菜单函数的实现
二、头文件实现
Contact.h
SeqList.h
三、Test.h
四、通讯录的初始化和销毁
五、增加通讯录
六、在通讯录中查找姓名下标
七、删除通讯录
八、显示通讯录
九、查找通讯录 一、设计框架 test.c#xff1a;通…目录
一、设计框架
1、功能要求
2、菜单函数的实现
二、头文件实现
Contact.h
SeqList.h
三、Test.h
四、通讯录的初始化和销毁
五、增加通讯录
六、在通讯录中查找姓名下标
七、删除通讯录
八、显示通讯录
九、查找通讯录 一、设计框架 test.c通讯录的总体逻辑测试通讯录的相关功能 contact.c通讯录的实现模块 contact.h通讯录的各种声明包括库函数、自定义函数以及自定义结构体的声明 1、功能要求
至少能够存储100个人的通讯信息能够保存用户信息名字、性别、年龄、电话、地址等增加联系人信息删除指定联系人查找制定联系人修改指定联系人显示联系人信息 2、菜单函数的实现 实现通讯录建立一个菜单是很重要的并且菜单要包含通讯录所有的功能以便于用户的操作 //通讯录菜单
void menu() {printf(*****************通讯录***************\n);printf(*******1.添加联系人 2.删除联系人*****\n);//ctrldprintf(*******3.修改联系人 4.查找联系人*****\n);//ctrldprintf(*******5.查看通讯录 0. 退 出 ******\n);//ctrldprintf(**************************************\n);
} 二、头文件实现
问题头文件包含嵌套 解决方案前置声明 Contact.h
#pragma once
//#includestdio.h //暂时加上#define NAME_MAX 100
#define GENDER_MAX 10
#define TEL_MAX 12
#define ADDR_MAX 100//通讯录数据类型
typedef struct PersonInfo
{char name[NAME_MAX];int age;char gender[GENDER_MAX];char tel[TEL_MAX];char addr[ADDR_MAX];
}Info;//使用顺序表的前置声明
struct SeqList;typedef struct SeqList Contact;//通讯里提供的操作//通讯录的初始化和销毁
void ContactInit(Contact* pcon);//实际初始化的还是顺序表
void ContactDesTroy(Contact* pcon);//增加、删除、修改、查找、查看通讯录
void ContactAdd(Contact* pcon);
void ContactDel(Contact* pcon);
void ContactModify(Contact* pcon);
void ContactFind(Contact* pcon);
void ContactShow(Contact* pcon);
SeqList.h
#pragma once
#define _CRT_SECURE_NO_WARNINGS 1
#includestdio.h
#includestdlib.h
#includeassert.h
#includeContact.h//静态顺序表//#define N 100
//struct SeqList
//{
// SLDataType a[N];
// int size;
//};//动态顺序表//typedef int SLDataType;
typedef Info SLDataType;typedef struct SeqList
{SLDataType* arr; //存储数据的底层结构int capacity; //记录顺序表的空间大小int size; //记录顺序表当前有效的数据个数
}SL;//typedef struct SeqList SL;//初始化和销毁
void SLInit(SL* ps);
void SLDestroy(SL* ps);
void SLPrint(SL* ps); //保持接口一致性//顺序表的头部/尾部插入
void SLPushBack(SL* ps, SLDataType x);
void SLPushFront(SL* ps, SLDataType x);//顺序表的头部/尾部删除
void SLPopBack(SL* ps);
void SLPopFront(SL* ps);//指定位置之前插入数据
//删除指定位置数据
void SLInsert(SL* ps, int pos, SLDataType x);
void SLErase(SL* ps, int pos);
//int SLFind(SL* ps, SLDataType x);
三、Test.h
我们需要根据菜单里面的选项来选择进行我们需要实现的功能比如我们想添加联系人我们就输入1就会进行用户假如的操作我们想退出程序我们输入0就可以退出。可以利用switch选择语句来实现各自的功能。
//#includeContact.h //在SeqList.h文件中已经包了Contact.h
#includeSeqList.h//通讯录菜单
void menu() {printf(*****************通讯录***************\n);printf(*******1.添加联系人 2.删除联系人*****\n);//ctrldprintf(*******3.修改联系人 4.查找联系人*****\n);//ctrldprintf(*******5.查看通讯录 0. 退 出 ******\n);//ctrldprintf(**************************************\n);
}
int main()
{int op -1;//创建通讯录结构对象Contact con;ContactInit(con);do {menu();printf(请选择您的操作:\n);scanf(%d, op);switch (op){case 1://添加联系人ContactAdd(con);break;case 2://删除联系人ContactDel(con);break;case 3://修改联系人ContactModify(con);break;case 4://查找联系人ContactFind(con);break;case 5://查看通讯录ContactShow(con);break;case 0://退出通讯录printf(通讯录退出中...\n);break;default:break;}} while (op ! 0);//销毁通讯录ContactDesTroy(con);return 0;
}
四、通讯录的初始化和销毁
ContactInit初始化通讯录。它调用SLInit来确保通讯录被视为顺序表的内部状态是干净的即没有分配内存且大小与容量均为0。ContactDesTroy销毁通讯录。它调用SLDestroy来释放通讯录占用的内存资源并确保通讯录回到初始状态。SLInit初始化顺序表。它将顺序表的数组指针设为NULL大小与容量均设为0表示这是一个空表。SLDestroy销毁顺序表。它首先检查顺序表指针是否为空然后释放数组内存将数组指针设为NULL并将大小与容量重置为0。
//通讯录的初始化和销毁
//SL* ps
void ContactInit(Contact* pcon) {SLInit(pcon);
}void ContactDesTroy(Contact* pcon) {SLDestroy(pcon);
}
//初始化和销毁
void SLInit(SL* ps) {ps-arr NULL; //不是int 而是Info类型 ps-size ps-capacity 0;
}
void SLDestroy(SL* ps) {assert(ps);if (ps-arr) {free(ps-arr);}ps-arr NULL;ps-size ps-capacity 0;
}
五、增加通讯录
这段代码主要实现了两个功能添加联系人到通讯录ContactAdd函数和在顺序表尾部插入数据SLPushBack函数。
1. 添加联系人到通讯录ContactAdd函数 首先定义了一个Info类型的结构体变量info用于存储输入的联系人信息。 然后通过一系列printf和scanf函数从用户那里获取联系人的姓名、年龄、性别、电话和住址并保存到info结构体中。 最后调用SLPushBack函数将这个联系人的信息添加到通讯录实际上是一个顺序表中。
2. 在顺序表尾部插入数据SLPushBack函数 首先使用assert函数检查传入的顺序表指针ps是否为空。如果为空程序将终止运行。这是一种防止程序出错的方式。 然后调用SLCheckCapacity函数检查顺序表的容量是否足够。如果不够该函数可能会进行扩容操作。 最后如果顺序表的空间足够就直接在尾部插入数据并更新顺序表的大小。 //增加通讯录
void ContactAdd(Contact* pcon) {//创建联系人结构体变量Info info;printf(请输入联系人姓名\n);scanf(%s, info.name);printf(请输入联系人年龄\n);scanf(%d, info.age);//其他数据都是数组,年龄不是printf(请输入联系人性别\n);scanf(%s, info.gender);printf(请输入联系人电话\n);scanf(%s, info.tel);printf(请输入联系人住址\n);scanf(%s, info.addr);//保存数据到通讯录顺序表SLPushBack(pcon, info);
}
//顺序表的头部/尾部插入
void SLPushBack(SL* ps, SLDataType x) {//断言--粗暴的解决方式//assert(ps ! NULL);assert(ps);//if判断--温柔的解决方式//if (ps NULL) {// return;//}//空间不够扩容SLCheckCapacity(ps);//空间足够直接插入ps-arr[ps-size] x;//ps-size;
}
六、在通讯录中查找姓名下标
使用 for 循环遍历通讯录中的每一个联系人。循环变量 i 从 0 开始直到通讯录的大小 pcon-size。在每次循环中使用 strcmp 函数比较当前联系人的姓名 pcon-arr[i].name 和要查找的姓名 name。strcmp 函数用于比较两个字符串是否相同。如果 strcmp 函数返回 0表示找到了姓名匹配的联系人。此时直接返回该联系人在通讯录中的下标 i。如果循环结束后仍然没有找到匹配的联系人函数返回 -1表示查找失败。
//在通讯录中查找姓名下标
int FindByName(Contact* pcon, char name[]) {for (int i 0; i pcon-size; i){if (strcmp(pcon-arr[i].name, name) 0) {//找到了,返回下标return i;}}return -1;
}
七、删除通讯录
首先函数会提示用户输入要删除的联系人的姓名。然后它会调用 FindByName 函数这个函数在之前的解释中已经介绍过它的作用是在通讯录中查找指定姓名的联系人的下标。如果 FindByName 函数返回的下标小于0说明通讯录中没有这个姓名的联系人函数就会打印一条提示信息然后结束。如果找到了这个姓名的联系人即 FindByName 返回的下标非负函数就会调用 SLErase 函数来执行删除操作。删除操作成功后函数会打印一条提示信息告知用户联系人已经成功删除。
void ContactDel(Contact* pcon) {//删除之前一定要先查找//找到了可以删除//找不到,不能执行删除printf(请输入要删除的联系人姓名:\n);char name[NAME_MAX];scanf(%s, name);int findIndex FindByName(pcon, name);if (findIndex 0) {printf(要删除的联系人不存在\n);return;}//执行删除操作SLErase(pcon, findIndex);printf(联系人删除成功\n);
}
函数首先会检查传入的顺序表指针和位置参数是否有效。如果顺序表指针为空或者位置参数超出了顺序表的大小范围函数就会通过 assert 宏终止程序运行防止发生错误。如果参数有效函数就会从指定位置开始将后面每个位置的数据都向前移动一个位置覆盖掉当前位置的数据。这样就相当于删除了指定位置的数据。数据移动完成后函数会将顺序表的大小减1因为已经删除了一个数据。
//删除指定位置数据
void SLErase(SL* ps, int pos) {assert(ps);assert(pos 0 pos ps-size);//pos以后的数据往前挪动一位for (int i pos; i ps-size - 1; i){ps-arr[i] ps-arr[i 1];//ps-arr[i-2] ps-arr[i-1];}ps-size--;
}
八、显示通讯录
void ContactShow(Contact* pcon) {//格式大家下去感兴趣去调整printf(%s %s %s %s %s\n, 姓名, 性别, 年龄, 电话, 住址);for (int i 0; i pcon-size; i){printf(%s %s %d %s %s\n,pcon-arr[i].name,pcon-arr[i].gender,pcon-arr[i].age,pcon-arr[i].tel,pcon-arr[i].addr);}
}
九、查找通讯录
调用 FindByName 函数该函数在之前的代码段中定义在通讯录中查找指定姓名的联系人的下标。将返回的下标存储在 findIndex 变量中。判断 findIndex 的值如果 findIndex 小于 0表示没有找到匹配的联系人于是打印一条提示信息并结束函数。如果 findIndex 非负表示找到了匹配的联系人继续执行下一步。打印找到的联系人的信息首先打印一列标题包括“姓名”、“性别”、“年龄”、“电话”和“住址”。然后根据 findIndex 下标从通讯录中获取对应联系人的信息并打印出来。
void ContactFind(Contact* pcon) {char name[NAME_MAX];printf(请输入要查找的用户姓名\n);scanf(%s, name);int findIndex FindByName(pcon, name);if (findIndex 0) {printf(该联系人不存在\n);return;}//找到了打印一下查找的联系人信息printf(%s %s %s %s %s\n, 姓名, 性别, 年龄, 电话, 住址);printf(%s %s %d %s %s\n,pcon-arr[findIndex].name,pcon-arr[findIndex].gender,pcon-arr[findIndex].age,pcon-arr[findIndex].tel,pcon-arr[findIndex].addr);
}
今天就先到这了 看到这里了还不给博主扣个 ⛳️ 点赞☀️收藏 ⭐️ 关注
你们的点赞就是博主更新最大的动力 有问题可以评论或者私信呢秒回哦。 我的博客即将同步至腾讯云开发者社区邀请大家一同入驻
腾讯云自媒体分享计划 - 腾讯云开发者社区-腾讯云