目录
题目描述:
解题思路:
完整代码:
9.24.1.h 函数和结构体的声明,以及头文件的引用
9.24.1.c 通讯录的菜单以及主函数
9.24.2.c 各种功能的实现
题目描述:
运用c语言编写一个类似于手机通讯录的代码,需要涉及添加,删除,查找,修改,显示,排列等功能。
解题思路:9.24.1.c 通讯录的菜单以及主函数
9.24.2.c 各种功能的实现
9.24.1.h 函数和结构体的声明,以及头文件的引用
完整代码: 9.24.1.h 函数和结构体的声明,以及头文件的引用#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include
#include
#define MAX 100
#define MAX_NAME 20
#define MAX_SEX 15
#define MAX_TELE 12
#define MAX_ID 30
struct perimformation
{//个人信息
char name[MAX_NAME];//姓名
char sex[MAX_SEX];//性别
char tele[MAX_TELE];//电话号码
int age;//年龄
char id[MAX_ID];//身份z
};
struct Contact
{
struct perimformation data[MAX];
int sz;
};
void Int_Contact(struct Contact* pc);//初定义结构体
void ADD_Contact(struct Contact *pc);//添加个人信息
void Show_Contact(struct Contact* pc);//展示个人信息
void Del_Contact(struct Contact* pc);//删除个人信息
void Search_Contact(struct Contact* pc);//查找个人信息
void Modify_Contact(struct Contact* pc);//修改个人信息
void Sort_Contact(struct Contact* pc);//排序个人信息
9.24.1.c 通讯录的菜单以及主函数
#include"9.24.1.h"
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;//创建通讯录
Int_Contact(&con);//初始化通讯录
do
{
menu();
printf("请选择->:\n");
scanf("%d", &input);
switch (input)
{//创建通讯录
case 1:
ADD_Contact(&con);
break;
case 2:
Del_Contact(&con);
break;
case 3:
Search_Contact(&con);
break;
case 4:
Modify_Contact(&con);
break;
case 5:
Show_Contact(&con);
break;
case 6:
Sort_Contact(&con);
break;
case 0:
printf("退出通讯录\n");
break;
default:
printf("选择错误,重新选择\n");
break;
}
}while (input);
return 0;
}
9.24.2.c 各种功能的实现
#include"9.24.1.h"
void Int_Contact(struct Contact* pc)
{//初始化结构体
assert(pc);
pc->sz = 0;
memset(pc->data, 0, MAX * sizeof(struct perimformation));
}
void ADD_Contact(struct Contact* pc)
{//增加通讯录的信息
assert(pc);
if (pc->sz == MAX)
{
printf("通讯录数据已满,无法添加通讯录数据\n");
return;
}
//添加信息
printf("请输入姓名:");
scanf("%s", pc->data[pc->sz].name);
printf("请输入性别:");
scanf("%s", pc->data[pc->sz].sex);
printf("请输入电话号码:");
scanf("%s", pc->data[pc->sz].tele);
printf("请输入年龄:");
scanf("%d", &(pc->data[pc->sz].age));
printf("请输入身份z:");
scanf("%s", pc->data[pc->sz].id);
pc->sz++;
printf("信息添加成功\n");
}
void Show_Contact(const struct Contact* pc)
{//显示身份信息
int i = 0;
printf("%-20s\t%-15s\t%-12s\t%-5s\t%-30s\n", "名字","性别","电话","年龄","身份z");
for (int i = 0; i < pc->sz; i++)
{
printf("%-20s\t%-15s\t%-12s\t%-5d\t%-30s\n", pc->data[i].name, pc->data[i].sex,
pc->data[i].tele, pc->data[i].age, pc->data[i].id);
}
}
int FindbyNAME(struct Contact* pc, char NAME[])
{
int i = 0;
for (int i = 0; i < pc->sz; i++)
{
if (0 == strcmp(pc->data[i].name, NAME))
{
return i;
}
}
return -1;
}
void Del_Contact(struct Contact* pc)
{
char NAME[MAX_NAME];
printf("请输入要删除的人的名字:");
scanf("%s", NAME);
//查找一下是否存在要删除的人的名字
int ret=FindbyNAME(pc, NAME);
if (ret == -1)
printf("要删除的人不存在\n");
else
{//删除
int j = 0;
for (int j = ret; j < pc->sz - 1; j++)
{
pc->data[j] = pc->data[j + 1];
}
pc->sz--;
printf("成功删除指定联系人\n");
}
}
void Search_Contact(struct Contact* pc)
{
char NAME[MAX_NAME];
printf("请输入要查找的人的名字");
scanf("%s", NAME);
//查找一下是否存在要查找的人的名字
int ret = FindbyNAME(pc, NAME);
if (ret == -1)
printf("要查找的人不存在\n");
else
{
printf("%-20s\t%-15s\t%-12s\t%-5s\t%-30s\n", "名字", "性别", "电话", "年龄", "身份z");
printf("%-20s\t%-15s\t%-12s\t%-5d\t%-30s\n", pc->data[ret].name, pc->data[ret].sex,
pc->data[ret].tele, pc->data[ret].age, pc->data[ret].id);
}
}
void Modify_Contact(struct Contact* pc)
{
char NAME[MAX_NAME];
printf("请输入要修改的人的名字");
scanf("%s", NAME);
int ret = FindbyNAME(pc, NAME);
if (ret == -1)
printf("要修改的人不存在\n");
else
{
//修改信息
printf("请输入姓名:");
scanf("%s", pc->data[ret].name);
printf("请输入性别:");
scanf("%s", pc->data[ret].sex);
printf("请输入电话号码:");
scanf("%s", pc->data[ret].tele);
printf("请输入年龄:");
scanf("%d", &(pc->data[ret].age));
printf("请输入身份z:");
scanf("%s", pc->data[ret].id);
printf("信息修改成功\n");
}
}
int cmp_name(const void* e1, const void* e2)
{//以名字排序
return strcmp(((struct perimformation*)e1)->name, ((struct perimformation*)e2)->name);
}
int cmp_age(void* e1, void* e2)
{//以年龄排序
return ((struct perimformation*)e1)->age-((struct perimformation*)e2)->age;
}
void Sort_Contact(struct Contact* pc)
{//排序
qsort(pc->data, pc->sz, sizeof(struct perimformation), cmp_name);
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)