C语言结构体实战项目------------《通讯录》(下)

简介: C语言结构体实战项目------------《通讯录》

源码:


contact.c


#include "contact.h"#include <string.h>#include <assert.h>voidInitContact(structContact*pc) {
assert(pc);
pc->sz=0;
memset(pc->data, 0, 100*sizeof(structPeoInfo));
}
voidAddContact(structContact*pc) {
//判断通讯录人员是否满了assert(pc);   //确保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("%d", &(pc->data[pc->sz].age));
printf("请输入电话:");
scanf("%s", pc->data[pc->sz].tele);
printf("请输入地址:");
scanf("%s", pc->data[pc->sz].addr);
pc->sz++;
printf("成功增加联系人\n");
}
voidShowContact(conststructContact*pc) {
inti=0;
printf("%-20s\t%-5s\t%-5s\t%-12s\t%-30s\n", "姓名", "性别", "年龄", "电话", "地址");
for (i=0; i<pc->sz; i++)
    {
printf("%-20s\t%-5s\t%-5d\t%-12s\t%-30s\n", pc->data[i].name,
pc->data[i].sex,
pc->data[i].age,
pc->data[i].tele,
pc->data[i].addr);
    }
}
intFindByName(conststructContact*pc, charname[])
{
inti=0;
for (i=0; i<pc->sz; i++)
    {
if (0==strcmp(pc->data[i].name, name))
        {
returni;
        }
    }
return-1;
}
voidDelContact(structContact*pc) {
charname[MAX_NAME];
printf("请输入要删除人的名字:");
scanf("%s", name);
//查找一下指定的人是否存在intret=FindByName(pc, name);
if (ret==-1)
printf("要删除的人不存在\n");
else    {
//删除intj=0;
for (j=ret; j<pc->sz-1; j++)
        {
pc->data[j] =pc->data[j+1];
        }
pc->sz--;
printf("成功删除指定联系人\n");
    }
}
voidSearchContact(conststructContact*pc) {
charname[MAX_NAME];
printf("请输入要查找的人的名字:");
scanf("%s", name);
//查找一下指定的人是否存在intret=FindByName(pc, name);
if (ret==-1)
printf("要查找的人不存在\n");
else    {
printf("%-20s\t%-5s\t%-5s\t%-12s\t%-30s\n", "姓名", "性别", "年龄", "电话", "地址");
printf("%-20s\t%-5s\t%-5d\t%-12s\t%-30s\n", pc->data[ret].name,
pc->data[ret].sex,
pc->data[ret].age,
pc->data[ret].tele,
pc->data[ret].addr);
    }
}
voidModifyContact(structContact*pc) {
printf("请输入要修改人的名字:>");
charname[MAX_NAME];
scanf("%s", name);
intret=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("%d", &(pc->data[ret].age));
printf("请输入电话:");
scanf("%s", pc->data[ret].tele);
printf("请输入地址:");
scanf("%s", pc->data[ret].addr);
printf("修改成功\n");
    }
}
intCmpByAge(constvoid*e1, constvoid*e2)
{
return ((structPeoInfo*)e1)->age- ((structPeoInfo*)e2)->age;
}
//按照年龄来排序voidSortContact(structContact*pc)
{
qsort(pc->data, pc->sz, sizeof(structPeoInfo), CmpByAge);
}


test.c


#define _CRT_SECURE_NO_WARNINGS 1#include <stdio.h>#include "contact.h"voidmenu() {
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");
}
intmain() {
intinput=0;
structContactcon;//创建通讯录InitContact(&con); //初始化通讯录do {
menu();
printf("请选择:");
scanf("%d", &input);
switch (input)
        {
case1:
AddContact(&con);
break;
case2:
DelContact(&con);
break;
case3:
SearchContact(&con);
break;
case4:
ModifyContact(&con);
break;
case5:
ShowContact(&con);
break;
case6:
SortContact(&con);
break;
case0:
break;
default:
break;
        }
    } while (input);
return0;
}


contact.h


1.#defineMAX100#define MAX_NAME 20#define MAX_SEX 5#define MAX_TELE 12#define MAX_ADDR 30//表示一个人的信息structPeoInfo {
charname[MAX_NAME];
charsex[MAX_SEX];
chartele[MAX_TELE];
intage;
charaddr[MAX_ADDR];
};
//完整的通讯录  structContact {
structPeoInfodata[MAX];
intsz; //sz表示人数,如果写入一个人的信息,让sz++,来达到统计人数的效果};
//初始化通讯录voidInitContact(structContact*pc);
//添加联系人信息到通讯录voidAddContact(structContact*pc);
//显示通讯录联系人信息voidShowContact(conststructContact*pc);
//删除指定联系人信息voidDelContact(structContact*pc);
//查找联系人信息voidSearchContact(conststructContact*pc);
//修改联系人信息voidModifyContact(structContact*pc);
//排序联系人信息voidSortContact(conststructContact*pc);


三,总结


通讯录的实现看似不难,但是在一些细节上还是挺复杂,里面涉及到结构体是的知识较为广泛,包括结构体传参,结构体指针等等,如对上文有意见或者有错误,还请大佬们斧正,觉得有帮助的童鞋们,创作不易,蟹蟹三连!

目录
相关文章
|
11月前
|
存储 网络协议 编译器
【C语言】深入解析C语言结构体:定义、声明与高级应用实践
通过根据需求合理选择结构体定义和声明的放置位置,并灵活结合动态内存分配、内存优化和数据结构设计,可以显著提高代码的可维护性和运行效率。在实际开发中,建议遵循以下原则: - **模块化设计**:尽可能封装实现细节,减少模块间的耦合。 - **内存管理**:明确动态分配与释放的责任,防止资源泄漏。 - **优化顺序**:合理排列结构体成员以减少内存占用。
871 14
|
11月前
|
存储 编译器 C语言
【C语言】结构体详解 -《探索C语言的 “小宇宙” 》
结构体通过`struct`关键字定义。定义结构体时,需要指定结构体的名称以及结构体内部的成员变量。
592 10
|
12月前
|
存储 C语言
C语言如何使用结构体和指针来操作动态分配的内存
在C语言中,通过定义结构体并使用指向该结构体的指针,可以对动态分配的内存进行操作。首先利用 `malloc` 或 `calloc` 分配内存,然后通过指针访问和修改结构体成员,最后用 `free` 释放内存,实现资源的有效管理。
1049 13
|
12月前
|
存储 编译器 数据处理
C 语言结构体与位域:高效数据组织与内存优化
C语言中的结构体与位域是实现高效数据组织和内存优化的重要工具。结构体允许将不同类型的数据组合成一个整体,而位域则进一步允许对结构体成员的位进行精细控制,以节省内存空间。两者结合使用,可在嵌入式系统等资源受限环境中发挥巨大作用。
377 12
|
12月前
|
存储 数据建模 程序员
C 语言结构体 —— 数据封装的利器
C语言结构体是一种用户自定义的数据类型,用于将不同类型的数据组合在一起,形成一个整体。它支持数据封装,便于管理和传递复杂数据,是程序设计中的重要工具。
|
12月前
|
存储 人工智能 算法
数据结构实验之C 语言的函数数组指针结构体知识
本实验旨在复习C语言中的函数、数组、指针、结构体与共用体等核心概念,并通过具体编程任务加深理解。任务包括输出100以内所有素数、逆序排列一维数组、查找二维数组中的鞍点、利用指针输出二维数组元素,以及使用结构体和共用体处理教师与学生信息。每个任务不仅强化了基本语法的应用,还涉及到了算法逻辑的设计与优化。实验结果显示,学生能够有效掌握并运用这些知识完成指定任务。
230 4
|
存储 C语言
【C语言】 条件操作符 -- 逗号表达式 -- []下标访问操作符,()函数调用操作符 -- 常见关键字 -- 指针 -- 结构体
【C语言】 条件操作符 -- 逗号表达式 -- []下标访问操作符,()函数调用操作符 -- 常见关键字 -- 指针 -- 结构体
【C语言】——define和指针与结构体初识
【C语言】——define和指针与结构体初识
|
存储 算法 Linux
初识C语言【补】——指针、结构体
初识C语言【补】——指针、结构体
161 0
初识C语言【补】——指针、结构体
|
存储 编译器 C语言
初识C语言系列-5-完结篇-#define,指针,结构体(二)
初识C语言系列-5-完结篇-#define,指针,结构体
初识C语言系列-5-完结篇-#define,指针,结构体(二)