实现一个通讯录:
通讯录可以用来存储1000个人的信息,每个人的信息包括:姓名、性别、年龄、电话、住址
提供方法:
添加联系人信息;
删除指定联系人信息;
查找指定联系人信息;
修改指定联系人信息;
显示所有联系人信息;
清空所有联系人;
以名字排序所有联系人;
第一步:
分别创建test.c ,tool.c ,too1.h 三个文件分别用来保存界面实现,游戏实现,函数声明。
第二步:test.c(源文件)
在源文件的主函数中创建menu(菜单),告诉玩家怎么操作!
并利用do-while语句,进入操作界面,通过scanf来实现操作输入,显示。
用户根据需求进行不同数字输入来进行不同操作。
自此,源文件基本操作实现完成。
#pragma once #define _CRT_SECURE_NO_WARNINGS 1 #include "test.h" enum Option { EXIT, ADD, DELE, SEARCH, MODIFY, SHOW, SORT, CLEAR }; void menu() { printf("****1.添加******\n"); printf("****2.删除******\n"); printf("****3.查找******\n"); printf("****4.修改******\n"); printf("****5.显示******\n"); printf("****6.排序******\n"); printf("****7.清空******\n"); printf("****0.退出******\n"); } int main() { Contact con;//通讯录 //初始化通讯录 InitContact(&con); int input = 0; do { menu(); printf("请输入要执行的操作:\n"); scanf("%d",&input); switch (input) { case ADD: ADDContact(&con); break; case DELE: DELEContact(&con); break; case SEARCH: SEARCHContact(&con); break; case MODIFY: MODIFYContact(&con); break; case SHOW: SHOWContact(&con); break; case SORT: SORTContact(&con); break; case EXIT: SAVEContact(&con); DestroyContact(&con); printf("退出通讯录成功!\n"); break; case CLEAR: CLEARContact(&con); printf("清空成功!\n"); break; default : printf("输入格式错误,请重新输入!\n"); break; } } while (input); return 0; }
第三步:tool.h(通讯录函数声明)
创建通讯录的结构体,通过这个结构体去调用存储这些信息的结构体;完成在tool.h中增加联系人都通讯录ADDContact(),删除指定联系人DELEContact(),查找指定联系人SEARCHContact(),修改指定联系人MODIFYContact(),打印通讯中的信息SHOWContact(),按照名字来排序SORTContact(),保存通讯录的信息到文件SAVEContact(),销毁通讯录CLEARContact(),加载文件的信息到通讯录LoadContact(),清空通讯录CLEARContact()的函数声明。
#pragma once #include <stdio.h> #include <assert.h> #include <string.h> #include <stdlib.h> //扩容时的扩容值 #define DEFAULT_SZ 3 #define INC_SZ 2 #define MAX 100 #define MAX_NAME 20 #define MAX_SEX 10 #define MAX_TELE 12 #define MAX_ADDR 30 // typedef struct PeoInfo { char name[MAX_NAME]; int age; char sex[MAX_SEX]; char tele[MAX_TELE]; char addr[MAX_ADDR]; }PeoInfo; //通讯录结构体 typedef struct Contact { PeoInfo* data;//存放人的信息 int count;//记录当前通讯录中实际人的个数 int capacity;//当前通讯录的容量 }Contact; //初始化通讯录 int InitContact(Contact* pc); //销毁通讯录 void DestroyContact(Contact* pc); //增加联系人都通讯录 void ADDContact(Contact* pc); //打印通讯中的信息 void SHOWContact(const Contact* pc); //删除指定联系人 void DELEContact(Contact* pc); //查找指定联系人 void SEARCHContact(Contact* pc); //修改指定联系人 void MODIFYContact(Contact* pc); //排序通讯录中内容 //按照名字来排序 void SORTContact(Contact* pc); //保存通讯录的信息到文件 void SAVEContact(const Contact* pc); //加载文件的信息到通讯录 void LoadContact(Contact* pc); //清空通讯录 void CLEARContact(Contact* pc);
第四步:tool.c(通讯录实现)
完成在tool.h中初始化通讯录InitContact(),增加联系人都通讯录ADDContact(),删除指定联系人DELEContact(),查找指定联系人SEARCHContact(),修改指定联系人MODIFYContact(),打印通讯中的信息SHOWContact(),按照名字来排序SORTContact(),保存通讯录的信息到文件SAVEContact(),销毁通讯录DestroyContact(),加载文件的信息到通讯录LoadContact(),清空通讯录CLEARContact()的实现。
首先:
对通讯录初始化InitContac),开辟(PeoInfo*)类型的动态内存,并设置动态容量为DEFAULT_SZ然后再加载之前的通讯录信息,如果开辟的内存不够,再动态多开辟INC_SZ个内存空间。
#include "test.h" //初始化通讯录 //void InitContact(Contact* pc) //{ // assert(pc); // pc->count = 0; // memset(pc->data,0,sizeof(pc->data)); //} void CheckCapacity(Contact* pc) { if (pc->count == pc->capacity) { PeoInfo* ptr = (PeoInfo*)realloc(pc->data, (pc->capacity + INC_SZ) * sizeof(PeoInfo)); if (ptr == NULL) { printf("AddContact::%s\n", strerror(errno)); return; } else { pc->data = ptr; pc->capacity += INC_SZ; printf("增容成功\n"); } } } //动态的版本 int InitContact(Contact* pc) { assert(pc); pc->count = 0; pc->data = (PeoInfo*)calloc(DEFAULT_SZ, sizeof(PeoInfo)); if (pc->data == NULL) { printf("InitContact::%s\n", strerror(errno)); return 1; } pc->capacity = DEFAULT_SZ; //加载文件的信息到通讯录中 LoadContact(pc); return 0; }
加载文件的信息到通讯录:
void LoadContact(Contact* pc) { FILE* pfRead = fopen("contact.txt", "rb"); if (pfRead == NULL) { perror("LoadContact"); return; } PeoInfo tmp = { 0 }; while (fread(&tmp, sizeof(PeoInfo), 1, pfRead) == 1) { CheckCapacity(pc); pc->data[pc->count] = tmp; pc->count++; } fclose(pfRead); pfRead = NULL; }
销毁通讯录:
void DestroyContact(Contact* pc) { assert(pc); free(pc->data); pc->data = NULL; }
增加联系人都通讯录:
//动态的版本 void ADDContact(Contact* pc) { assert(pc); // 增容 CheckCapacity(pc); /*if (pc->count == MAX) { printf("通讯录已满!\n"); return; }*/ printf("请输入名字:\n"); scanf("%s",pc->data[pc->count].name); printf("请输入年龄:\n"); scanf("%d",&(pc->data[pc->count].age)); printf("请输入性别:\n"); scanf("%s",pc->data[pc->count].sex); printf("请输入电话:\n"); scanf("%s",pc->data[pc->count].tele); printf("请输入地址:\n"); scanf("%s",pc->data[pc->count].addr); pc->count++; printf("添加成功!\n"); }
打印通讯中的信息:
void SHOWContact(const Contact* pc) { assert(pc); int i = 0; printf("%-20s\t%-5s\t%-5s\t%-12s\t%-20s\n","姓名","年龄","性别","电话","地址"); for (i = 0;i < pc->count;i++) { printf("%-20s\t%-5d\t%-5s\t%-12s\t%-30s\n",pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr); } }
删除指定联系人:
static int FindByName(Contact* pc, char name[]) { assert(pc); int i = 0; for (i = 0; i < pc -> count; i++) { if (strcmp(pc->data[i].name, name) == 0) { return i; } } return -1; } void DELEContact(Contact* pc) { assert(pc); int i = 0; char name[MAX_NAME] = { 0 }; if (pc->count == 0) { printf("通讯录为空,没有可删除的信息!\n"); return; } printf("请输入要删除的人的名字:\n"); scanf("%s", name); //查找 int pos = FindByName(pc, name); if (pos == -1) { printf("需要删除的人不存在!\n"); return; } //删除 for (i = pos; i < pc->count - 1; i++) { pc->data[i] = pc->data[i + 1]; } pc->count--; printf("删除成功!\n"); }
查找指定联系人:
void SEARCHContact(Contact* pc) { assert(pc); char name[MAX_NAME] = { 0 }; printf("请输入要查询的人的名字:\n"); scanf("%s",name); int pos = FindByName(pc,name); if (pos == -1) { printf("没有查找到此人:\n"); return; } //显示 printf("%-20s\t%-5s\t%-5s\t%-12s\t%-30s\n", "姓名", "年龄", "性别", "电话", "地址"); printf("%-20s\t%-5d\t%-5s\t%-12s\t%-30s\n", pc->data[pos].name, pc->data[pos].age, pc->data[pos].sex, pc->data[pos].tele, pc->data[pos].addr); }
修改指定联系人:
void MODIFYContact(Contact* pc) { assert(pc); char name[MAX_NAME] = { 0 }; printf("请输入要修改信息的人的名字:\n"); scanf("%s", name); int pos = FindByName(pc, name); if (pos == -1) { printf("没有找到需要修改信息的人:\n"); return; } printf("已找到需要修改信息的人,请修改:\n"); //修改 printf("请输入名字:\n"); scanf("%s",pc->data[pos].name); printf("请输入年龄:\n"); scanf("%d",&(pc->data[pos].age)); printf("请输入性别:\n"); scanf("%s",pc->data[pos].sex); printf("请输入电话:\n"); scanf("%s",pc->data[pos].tele); printf("请输入地址:\n"); scanf("%s",pc->data[pos].addr); printf("修改成功!\n"); }
按照名字来排序:
int cmp_Peo_age(const void* p1, const void* p2) { return strcmp(((PeoInfo*)p1)->name, ((PeoInfo*)p2)->name); } //按照名字来排序 void SORTContact(Contact* pc) { assert(pc); qsort(pc->data,pc->count,sizeof(PeoInfo),cmp_Peo_age); printf("排序完成!\n"); }
保存通讯录的信息到文件:
void SAVEContact(const Contact* pc) { assert(pc); FILE* pfWrite = fopen("contact.txt", "wb"); if (pfWrite == NULL) { perror("SAVEContact"); return; } //写文件-二进制的形式 int i = 0; for (i = 0; i < pc->count; i++) { fwrite(pc->data+i,sizeof(PeoInfo),1,pfWrite); } fclose(pfWrite); pfWrite = NULL; }
清空通讯录
在退出时,保存通讯录中的信息,再释放动态开辟的内存
//清空 void CLEARContact(Contact* pc) { assert(pc); pc->count = 0; pc->capacity = 0; memset(pc->data,0,sizeof(pc->data)); }
如下为tool.c的全部实现集合
#define _CRT_SECURE_NO_WARNINGS 1 #include "test.h" //初始化通讯录 //void InitContact(Contact* pc) //{ // assert(pc); // pc->count = 0; // memset(pc->data,0,sizeof(pc->data)); //} void CheckCapacity(Contact* pc) { if (pc->count == pc->capacity) { PeoInfo* ptr = (PeoInfo*)realloc(pc->data, (pc->capacity + INC_SZ) * sizeof(PeoInfo)); if (ptr == NULL) { printf("AddContact::%s\n", strerror(errno)); return; } else { pc->data = ptr; pc->capacity += INC_SZ; printf("增容成功\n"); } } } void LoadContact(Contact* pc) { FILE* pfRead = fopen("contact.txt", "rb"); if (pfRead == NULL) { perror("LoadContact"); return; } PeoInfo tmp = { 0 }; while (fread(&tmp, sizeof(PeoInfo), 1, pfRead) == 1) { CheckCapacity(pc); pc->data[pc->count] = tmp; pc->count++; } fclose(pfRead); pfRead = NULL; } //动态的版本 int InitContact(Contact* pc) { assert(pc); pc->count = 0; pc->data = (PeoInfo*)calloc(DEFAULT_SZ, sizeof(PeoInfo)); if (pc->data == NULL) { printf("InitContact::%s\n", strerror(errno)); return 1; } pc->capacity = DEFAULT_SZ; //加载文件的信息到通讯录中 LoadContact(pc); return 0; } void DestroyContact(Contact* pc) { assert(pc); free(pc->data); pc->data = NULL; } //动态的版本 void ADDContact(Contact* pc) { assert(pc); // 增容 CheckCapacity(pc); /*if (pc->count == MAX) { printf("通讯录已满!\n"); return; }*/ printf("请输入名字:\n"); scanf("%s",pc->data[pc->count].name); printf("请输入年龄:\n"); scanf("%d",&(pc->data[pc->count].age)); printf("请输入性别:\n"); scanf("%s",pc->data[pc->count].sex); printf("请输入电话:\n"); scanf("%s",pc->data[pc->count].tele); printf("请输入地址:\n"); scanf("%s",pc->data[pc->count].addr); pc->count++; printf("添加成功!\n"); } void SHOWContact(const Contact* pc) { assert(pc); int i = 0; printf("%-20s\t%-5s\t%-5s\t%-12s\t%-20s\n","姓名","年龄","性别","电话","地址"); for (i = 0;i < pc->count;i++) { printf("%-20s\t%-5d\t%-5s\t%-12s\t%-30s\n",pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr); } } static int FindByName(Contact* pc, char name[]) { assert(pc); int i = 0; for (i = 0; i < pc -> count; i++) { if (strcmp(pc->data[i].name, name) == 0) { return i; } } return -1; } void DELEContact(Contact* pc) { assert(pc); int i = 0; char name[MAX_NAME] = { 0 }; if (pc->count == 0) { printf("通讯录为空,没有可删除的信息!\n"); return; } printf("请输入要删除的人的名字:\n"); scanf("%s", name); //查找 int pos = FindByName(pc, name); if (pos == -1) { printf("需要删除的人不存在!\n"); return; } //删除 for (i = pos; i < pc->count - 1; i++) { pc->data[i] = pc->data[i + 1]; } pc->count--; printf("删除成功!\n"); } void SEARCHContact(Contact* pc) { assert(pc); char name[MAX_NAME] = { 0 }; printf("请输入要查询的人的名字:\n"); scanf("%s",name); int pos = FindByName(pc,name); if (pos == -1) { printf("没有查找到此人:\n"); return; } //显示 printf("%-20s\t%-5s\t%-5s\t%-12s\t%-30s\n", "姓名", "年龄", "性别", "电话", "地址"); printf("%-20s\t%-5d\t%-5s\t%-12s\t%-30s\n", pc->data[pos].name, pc->data[pos].age, pc->data[pos].sex, pc->data[pos].tele, pc->data[pos].addr); } void MODIFYContact(Contact* pc) { assert(pc); char name[MAX_NAME] = { 0 }; printf("请输入要修改信息的人的名字:\n"); scanf("%s", name); int pos = FindByName(pc, name); if (pos == -1) { printf("没有找到需要修改信息的人:\n"); return; } printf("已找到需要修改信息的人,请修改:\n"); //修改 printf("请输入名字:\n"); scanf("%s",pc->data[pos].name); printf("请输入年龄:\n"); scanf("%d",&(pc->data[pos].age)); printf("请输入性别:\n"); scanf("%s",pc->data[pos].sex); printf("请输入电话:\n"); scanf("%s",pc->data[pos].tele); printf("请输入地址:\n"); scanf("%s",pc->data[pos].addr); printf("修改成功!\n"); } int cmp_Peo_age(const void* p1, const void* p2) { return strcmp(((PeoInfo*)p1)->name, ((PeoInfo*)p2)->name); } //按照名字来排序 void SORTContact(Contact* pc) { assert(pc); qsort(pc->data,pc->count,sizeof(PeoInfo),cmp_Peo_age); printf("排序完成!\n"); } void SAVEContact(const Contact* pc) { assert(pc); FILE* pfWrite = fopen("contact.txt", "wb"); if (pfWrite == NULL) { perror("SAVEContact"); return; } //写文件-二进制的形式 int i = 0; for (i = 0; i < pc->count; i++) { fwrite(pc->data+i,sizeof(PeoInfo),1,pfWrite); } fclose(pfWrite); pfWrite = NULL; } //清空 void CLEARContact(Contact* pc) { assert(pc); pc->count = 0; pc->capacity = 0; memset(pc->data,0,sizeof(pc->data)); }