💐 🌸 🌷 🍀 🌹 🌻 🌺 🍁 🍃 🍂 🌿 🍄🍝 🍛 🍤
📃个人主页 :阿然成长日记 👈点击可跳转
📆 个人专栏: 🔹数据结构与算法🔹C语言进阶
🚩 不能则学,不知则问,耻于问人,决无长进
🍭 🍯 🍎 🍏 🍊 🍋 🍒 🍇 🍉 🍓 🍑 🍈 🍌 🍐 🍍
通讯录--C语言
- 🎈 一、初始版本
- 🌺二、动态扩容版本
- 🌵三、文件版(可长期保存数据)
- Contact.h
- Contact.c
- test.c
用c语言实现一个通讯录的系统,并且存储若干人的信息,每个人的信息包括:
姓名,性别,年龄,电话号码,住址。
此通讯录系统的功能包括:
1.增加联系人
2.删除对应的联系人
3.查找联系人
4.修改联系人的信息
5.排序此通讯录
6.打印出通讯录每个人的信息
设计
test.c--------------------测试通讯录的功能
contact.h---------------通讯录的实现(接口的声明)
contact.c---------------通讯录的实现(接口的实现)
🎈 一、初始版本
contact.h
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<assert.h>#define MAX 100
#define MAX_NAME 20
#define MAX_SEX 5
#define MAX_TELE 12
#define Max_ADDR 30enum OPTION
{EXIT,ADD,DLE,SEARCH,MODIFY,SHOW,SORT
};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[MAX];int sz;
}Contact;//初始化联系人
void InitContact(Contact* pc);//添加联系人+
void AddContact(Contact* pc);//显示联系人
void ShowContact(Contact* pc);//删除指定联系人(name)
void DelContact(Contact* pc);//查找一个人
void SearchContact(Contact* pc);//修改指定联系人信息
void ModifyContact(Contact* pc);//排序
void SortContact(Contact* pc);
test.c
#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"
void menu()
{printf("**********************************\n");printf("****1.增加 2.删除****\n");printf("****3.查找 4.修改****\n");printf("****5.展示 6.排序****\n");printf("****0.退出 ****\n");printf("**********************************\n");
}
void test()
{Contact con;//通讯录InitContact(&con);//初始化int input;do {menu();printf("请输入你的选则:");scanf("%d", &input);switch (input){case ADD:AddContact(&con);break;case DLE: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"); break;}} while (input);
}int main()
{test();return 0;
}
contact.c
#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"
//初始化联系人
void InitContact(Contact* pc)
{assert(pc);memset(pc->data, 0, sizeof(pc->data));pc->sz = 0;
}//添加联系人+
void AddContact(Contact* pc)
{assert(pc);//判断if (pc->sz == MAX){printf("通讯录已满,无法添加!");return;}//添加printf("请输入姓名:");scanf("%s", pc->data[pc->sz].name);printf("请输入年龄:");scanf("%d", &pc->data[pc->sz].age);printf("请输入性别:");scanf("%s", pc->data[pc->sz].sex);printf("请输入电话:");scanf("%s", pc->data[pc->sz].tele);printf("请输入住址:");scanf("%s", pc->data[pc->sz].addr);pc->sz++;printf("添加成功");
}//显示联系人
void ShowContact(const Contact* pc)//const修饰,不让其通过pc指针改变其指向内容。
{assert(pc);int i = 0;//打印表头printf("%-20s\t %2s\t %-5s\t %-12s\t %-20s\n", "名字", "年龄", "性别", "电话", "住址");//打印内容for (i = 0; i < pc->sz; i++){printf("%-20s\t %2d\t %-5s\t %-12s\t %-20s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}
}//查找
int FindByName(Contact* pc, char name[])
{int i = 0;//找到要删除的下标for (i = 0; i < pc->sz; i++){if (strcmp(pc->data[i].name, name) == 0){//记下找到的下标值return i;}}return -1;
}//删除指定联系人(name)
void DelContact(Contact* pc)
{char name[MAX_NAME];assert(pc);printf("请输入要删除的名字\n");scanf("%s", name);int i = 0;//如果为空,不删if (pc->sz == 0) {printf("通讯录为空\n");return;}int del = FindByName(pc, name);if (del == -1) {printf("没找到\n");return;}for (i = del; i < pc->sz - 1; i++) {pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功!\n");
}//查找一个人
void SearchContact(const Contact* pc)
{assert(pc);char name[MAX_NAME];printf("请输入要删除的名字\n");scanf("%s", name);int find = FindByName(pc, name);if (find == -1){printf("没有这个人\n");return;}//打印找到人的信息printf("%-20s\t %2d\t %-5s\t %-12s\t %-20s\n", "名字", "年龄", "性别", "电话", "住址");//打印内容printf("%-20s\t %2d\t %-5s\t %-12s\t %-20s\n",pc->data[find].name,pc->data[find].age,pc->data[find].sex,pc->data[find].tele,pc->data[find].addr);}//修改指定联系人信息
void ModifyContact(Contact* pc)
{assert(pc);printf("请输入要修改联系人的姓名:\n");char name[MAX_NAME];scanf("%s", name);int find = FindByName(pc, name);if (find == -1){printf("没有这个人\n");return;}printf("请输入要修改的内容:\n");printf("请输入姓名:");scanf("%s", pc->data[find].name);printf("请输入年龄:");scanf("%d", &pc->data[find].age);printf("请输入性别:");scanf("%s", pc->data[find].sex);printf("请输入电话:");scanf("%s", pc->data[find].tele);printf("请输入住址:");scanf("%s", pc->data[find].addr);printf("修改成功!!!!\n");
}//排序
//名字排序
int comper_name(const void* e1, const void* e2)
{return strcmp(((Contact*)e1)->data->name, ((Contact*)e2)->data->name);
}
//年龄排序
int comper_age(const void* e1, const void* e2)
{return ((Contact*)e1)->data->age - ((Contact*)e2)->data->age;
}
//性别排序
int comper_sex(const void* e1, const void* e2)
{return strcmp(((Contact*)e1)->data->sex, ((Contact*)e2)->data->sex);
}
//排序
void SortContact(Contact* pc)
{printf("***************************\n");printf("1. 名字排序 2. 年龄排序\n");printf("3. 性别排序 \n");printf("***************************\n");printf("请选择排序方法:");int input = 0;scanf("%d", &input);switch (input){case 1:qsort(pc->data, pc->sz, sizeof(PeoInfo), comper_name);ShowContact(pc);printf("排序成功\n");break;case 2:qsort(pc->data, pc->sz, sizeof(PeoInfo), comper_age);ShowContact(pc);printf("排序完成\n");break;case 3:qsort(pc->data, pc->sz, sizeof(PeoInfo), comper_sex);ShowContact(pc);printf("排序完成\n");break;default:printf("选择错误\n");break;}
}
🌺二、动态扩容版本
Contact.h
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<assert.h>
#include<stdlib.h>#define MAX_NAME 20
#define MAX_SEX 5
#define MAX_TELE 12
#define Max_ADDR 30
#define INT_SZ 2enum OPTION
{EXIT,ADD,DLE,SEARCH,MODIFY,SHOW,SORT
};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 sz;//记录当前存放有效数据int capacity;//记录当前的最大容量
}Contact;//初始化联系人
void InitContact(Contact* pc);//添加联系人+
void AddContact(Contact* pc);//显示联系人
void ShowContact(Contact* pc);//删除指定联系人(name)
void DelContact(Contact* pc);//查找一个人
void SearchContact(Contact* pc);//修改指定联系人信息
void ModifyContact(Contact* pc);//排序
void SortContact(Contact* pc);//释放空间
void DestroyContact(Contact* pc);
Contact.c
#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"
//初始化联系人
void InitContact(Contact* pc)
{assert(pc);pc->data = (PeoInfo*)malloc(sizeof(PeoInfo));pc->sz = 0;
}//扩容
int CheckCapacity(Contact* pc)
{if (pc->sz == pc->capacity){PeoInfo* ptr = (PeoInfo*)realloc(pc->data, (pc->capacity + INT_SZ) * sizeof(PeoInfo));if (ptr == NULL){printf("扩容失败!");perror("CheckCapacity");return 0;}else{pc->data = ptr;pc->capacity += INT_SZ;printf("扩容成功!");return 1;}}return 1;
}
//添加联系人+
void AddContact(Contact* pc)
{assert(pc);//判断if (CheckCapacity(pc) == 0){printf("添加失败,空间不足!");return;}if (CheckCapacity(pc) == 1){printf("扩容成功\n");//添加printf("请输入姓名:");scanf("%s", pc->data[pc->sz].name);printf("请输入年龄:");scanf("%d", &pc->data[pc->sz].age);printf("请输入性别:");scanf("%s", pc->data[pc->sz].sex);printf("请输入电话:");scanf("%s", pc->data[pc->sz].tele);printf("请输入住址:");scanf("%s", pc->data[pc->sz].addr);pc->sz++;printf("添加成功\n");}
}//显示联系人
void ShowContact(const Contact* pc)//const修饰,不让其通过pc指针改变其指向内容。
{assert(pc);int i = 0;//打印表头printf("%-20s\t %2s\t %-5s\t %-12s\t %-20s\n", "名字", "年龄", "性别", "电话", "住址");//打印内容for (i = 0; i < pc->sz; i++){printf("%-20s\t %2d\t %-5s\t %-12s\t %-20s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}
}//查找
int FindByName(Contact* pc, char name[])
{int i = 0;//找到要删除的下标for (i = 0; i < pc->sz; i++){if (strcmp(pc->data[i].name, name) == 0){//记下找到的下标值return i;}}return -1;
}//删除指定联系人(name)
void DelContact(Contact* pc)
{char name[MAX_NAME];assert(pc);printf("请输入要删除的名字\n");scanf("%s", name);int i = 0;//如果为空,不删if (pc->sz == 0) {printf("通讯录为空\n");return;}int del = FindByName(pc, name);if (del == -1) {printf("没找到\n");return;}for (i = del; i < pc->sz - 1; i++) {pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功!\n");
}//查找一个人
void SearchContact(const Contact* pc)
{assert(pc);char name[MAX_NAME];printf("请输入要删除的名字\n");scanf("%s", name);int find = FindByName(pc, name);if (find == -1){printf("没有这个人\n");return;}//打印找到人的信息printf("%-20s\t %-2s\t %-5s\t %-12s\t %-20s\n", "名字", "年龄", "性别", "电话", "住址");//打印内容printf("%-20s\t %-2d\t %-5s\t %-12s\t %-20s\n",pc->data[find].name,pc->data[find].age,pc->data[find].sex,pc->data[find].tele,pc->data[find].addr);}//修改指定联系人信息
void ModifyContact(Contact* pc)
{assert(pc);printf("请输入要修改联系人的姓名:\n");char name[MAX_NAME];scanf("%s", name);int find = FindByName(pc, name);if (find == -1){printf("没有这个人\n");return;}printf("请输入要修改的内容:\n");printf("请输入姓名:");scanf("%s", pc->data[find].name);printf("请输入年龄:");scanf("%d", &pc->data[find].age);printf("请输入性别:");scanf("%s", pc->data[find].sex);printf("请输入电话:");scanf("%s", pc->data[find].tele);printf("请输入住址:");scanf("%s", pc->data[find].addr);printf("修改成功!!!!\n");
}//排序联系人信息
void SortContact(struct Contact* pc)
{if (pc->sz == 0){printf("通讯录为空,无法排序!!!\n");return;}int i = 0;int j = 0;struct PeoInfo tmp;for (i = 0; i < pc->sz - 1; i++){int flag = 1;for (j = 0; j < pc->sz - i - 1; j++){if (strcmp(pc->data[j].name, pc->data[j + 1].name) < 0){tmp = pc->data[j];pc->data[j] = pc->data[j + 1];pc->data[j + 1] = tmp;flag = 0;}}if (flag == 1){return;}}printf("排序成功\n");
}//释放
void DestroyContact(Contact* pc)
{free(pc->data);pc->data = NULL;pc->capacity = 0;pc->sz = 0;
}
Teat.c
#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"
void menu()
{printf("**********************************\n");printf("****1.增加 2.删除****\n");printf("****3.查找 4.修改****\n");printf("****5.展示 6.排序****\n");printf("****0.退出 ****\n");printf("**********************************\n");
}
void test()
{Contact con;//通讯录InitContact(&con);//初始化int input;do {menu();printf("请输入你的选则:");scanf("%d", &input);switch (input){case ADD:AddContact(&con);break;case DLE: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:DestroyContact(&con);break;default:printf("选择错误,请重新输入\n"); break;}} while (input);
}int main()
{test();return 0;
}
🌵三、文件版(可长期保存数据)
Contact.h
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<assert.h>
#include<stdlib.h>#define MAX_NAME 20
#define MAX_SEX 5
#define MAX_TELE 12
#define Max_ADDR 30
#define INT_SZ 2enum OPTION
{EXIT,ADD,DLE,SEARCH,MODIFY,SHOW,SORT
};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 sz;//记录当前存放有效数据int capacity;//记录当前的最大容量
}Contact;//初始化联系人
void InitContact(Contact* pc);//添加联系人+
void AddContact(Contact* pc);//显示联系人
void ShowContact(Contact* pc);//删除指定联系人(name)
void DelContact(Contact* pc);//查找一个人
void SearchContact(Contact* pc);//修改指定联系人信息
void ModifyContact(Contact* pc);//排序
void SortContact(Contact* pc);//释放空间
void DestroyContact(Contact* pc); //保存联系人
void SaveContact(Contact* pc);//扩容
int CheckCapacity(Contact* pc);
Contact.c
#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"//从文件中加载数据void LoadContact(Contact* pc)
{FILE* pf = fopen("ContactData.text", "rb");if (pf == NULL){perror("LoadContact");return;}PeoInfo temp = { 0 };while (fread(&temp, sizeof(PeoInfo), 1, pf)){if (CheckCapacity(pc) == 0)return;pc->data[pc->sz] = temp;pc->sz++;}//关闭fclose(pf);pf = NULL;}//初始化联系人
void InitContact(Contact* pc)
{assert(pc);pc->data = (PeoInfo*)malloc(INT_SZ*sizeof(PeoInfo));if (pc->data == NULL){perror("InitContact");return;}pc->sz = 0;pc->capacity = INT_SZ;//加载联系人LoadContact(pc);
}//扩容
int CheckCapacity(Contact* pc)
{if (pc->sz == pc->capacity){PeoInfo* ptr = (PeoInfo*)realloc(pc->data, (pc->capacity + INT_SZ) * sizeof(PeoInfo));if (ptr == NULL){printf("扩容失败!");perror("CheckCapacity");return 0;}else{pc->data = ptr;pc->capacity += INT_SZ;printf("扩容成功!");return 1;}}return 1;
}
//添加联系人+
void AddContact(Contact* pc)
{assert(pc);//判断if (CheckCapacity(pc) == 0){printf("添加失败,空间不足!");return;}if (CheckCapacity(pc) == 1){printf("扩容成功\n");//添加printf("请输入姓名:");scanf("%s", pc->data[pc->sz].name);printf("请输入年龄:");scanf("%d", &pc->data[pc->sz].age);printf("请输入性别:");scanf("%s", pc->data[pc->sz].sex);printf("请输入电话:");scanf("%s", pc->data[pc->sz].tele);printf("请输入住址:");scanf("%s", pc->data[pc->sz].addr);pc->sz++;printf("添加成功\n");}
}//显示联系人
void ShowContact(const Contact* pc)//const修饰,不让其通过pc指针改变其指向内容。
{assert(pc);int i = 0;//打印表头printf("%-20s\t %2s\t %-5s\t %-12s\t %-20s\n", "名字", "年龄", "性别", "电话", "住址");//打印内容for (i = 0; i < pc->sz; i++){printf("%-20s\t %2d\t %-5s\t %-12s\t %-20s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}
}//查找
int FindByName(Contact* pc, char name[])
{int i = 0;//找到要删除的下标for (i = 0; i < pc->sz; i++){if (strcmp(pc->data[i].name, name) == 0){//记下找到的下标值return i;}}return -1;
}//删除指定联系人(name)
void DelContact(Contact* pc)
{char name[MAX_NAME];assert(pc);printf("请输入要删除的名字\n");scanf("%s", name);int i = 0;//如果为空,不删if (pc->sz == 0) {printf("通讯录为空\n");return;}int del = FindByName(pc, name);if (del == -1) {printf("没找到\n");return;}for (i = del; i < pc->sz - 1; i++) {pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功!\n");
}//查找一个人
void SearchContact(const Contact* pc)
{assert(pc);char name[MAX_NAME];printf("请输入要删除的名字\n");scanf("%s", name);int find = FindByName(pc, name);if (find == -1){printf("没有这个人\n");return;}//打印找到人的信息printf("%-20s\t %-2s\t %-5s\t %-12s\t %-20s\n", "名字", "年龄", "性别", "电话", "住址");//打印内容printf("%-20s\t %-2d\t %-5s\t %-12s\t %-20s\n",pc->data[find].name,pc->data[find].age,pc->data[find].sex,pc->data[find].tele,pc->data[find].addr);}//修改指定联系人信息
void ModifyContact(Contact* pc)
{assert(pc);printf("请输入要修改联系人的姓名:\n");char name[MAX_NAME];scanf("%s", name);int find = FindByName(pc, name);if (find == -1){printf("没有这个人\n");return;}printf("请输入要修改的内容:\n");printf("请输入姓名:");scanf("%s", pc->data[find].name);printf("请输入年龄:");scanf("%d", &pc->data[find].age);printf("请输入性别:");scanf("%s", pc->data[find].sex);printf("请输入电话:");scanf("%s", pc->data[find].tele);printf("请输入住址:");scanf("%s", pc->data[find].addr);printf("修改成功!!!!\n");
}//排序联系人信息
void SortContact(struct Contact* pc)
{if (pc->sz == 0){printf("通讯录为空,无法排序!!!\n");return;}int i = 0;int j = 0;struct PeoInfo tmp;for (i = 0; i < pc->sz - 1; i++){int flag = 1;for (j = 0; j < pc->sz - i - 1; j++){if (strcmp(pc->data[j].name, pc->data[j + 1].name) < 0){tmp = pc->data[j];pc->data[j] = pc->data[j + 1];pc->data[j + 1] = tmp;flag = 0;}}if (flag == 1){return;}}printf("排序成功\n");
}//释放
void DestroyContact(Contact* pc)
{free(pc->data);pc->data = NULL;pc->capacity = 0;pc->sz = 0;
}//保存联系人
void SaveContact(Contact* pc)
{FILE* pf = fopen("ContactData.text", "wb");if (pf == NULL){perror("SaveContact");return;}//写文件int i = 0;for (i = 0; i < pc->sz; i++){fwrite(pc->data,sizeof(PeoInfo),1,pf);}//关闭文件fclose(pf);pf == NULL;}
test.c
#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"
void menu()
{printf("**********************************\n");printf("****1.增加 2.删除****\n");printf("****3.查找 4.修改****\n");printf("****5.展示 6.排序****\n");printf("****0.退出 ****\n");printf("**********************************\n");
}
void test()
{Contact con;//通讯录InitContact(&con);//初始化int input;do {menu();printf("请输入你的选则:");scanf("%d", &input);switch (input){case ADD:AddContact(&con);break;case DLE: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:SaveContact(&con);printf("保存成功!!");DestroyContact(&con);printf("空间以释放!!");break;default:printf("选择错误,请重新输入\n"); break;}} while (input);
}int main()
{test();return 0;
}