通讯录实现

简介: 通讯录实现

下方是头文件的代码

#define _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include<stdio.h>
#include<string.h>
#include<stdlib.h>

#define NAME_MAX 20
#define SEX_MAX 6
#define TELE_MAX 12
#define ADDR_MAX 30
#define  MAX 100
#define DEFAULT_SZ 3
#define DEFAULT_INC

//类型声明
typedef struct PeoInfo
{
    char name[NAME_MAX];
    int age;
    char sex[SEX_MAX];
    char tele[TELE_MAX];
    char addr[ADDR_MAX];
}PeoInfo;

//静态通讯录版本
//typedef struct Contact
//{
//    PeoInfo data[MAX];//存放数据
//    int sz;//记录的是当前通讯录中存放的人的信息数
//}Contact;

//动态通讯录版本
    typedef struct Contact
    {
        PeoInfo* data;//存放数据
        int sz;//记录的是当前通讯录中存放的人的信息数
        int    capacity;//记录的是当前通讯录的容量
    }Contact;


//初始化通讯录
void InitContact(Contact* pc);
//增加联系人
void AddContact(Contact* pc);
//显示所有联系人
void ShowContact(Contact* pc);
//删除指定联系人
void DelContact(Contact* pc);
//查找指定联系人
void SearchContact(Contact* pc);
//修改指定联系人
void ModifyContact(Contact* pc);
//销毁通讯录
void DestroyContact(Contact* pc);

下方是各函数实现的代码:
```#include "contact.h"

//静态通讯录版本
//void InitContact(Contact* pc)
//{
// assert(pc);
// pc->sz = 0;
// memset(pc->data, 0, sizeof(pc->data));
//}

void InitContact(Contact* pc)
{
assert(pc);
pc->sz = 0;
pc->capacity = DEFAULT_SZ;
pc->data = calloc(pc->capacity , sizeof(PeoInfo));
if (pc->data == NULL)
{
perror("InitContact->calloc");
return;
}
}

void CheckCapacity(Contact pc)
{
if (pc->sz == pc->capacity)
{
PeoInfo
ptr = (PeoInfo)realloc(pc->data, (pc->capacity + DEFAULT_SZ) sizeof(PeoInfo));
if (ptr != NULL)
{
pc->data = ptr;
pc->capacity += 2;
printf("增容成功\n");
}
else
{
perror("AddContact->realloc");
return;
}
}
}

void DestroyContact(Contact* pc)
{
free(pc->data);
pc->data = NULL;
pc->sz = 0;
pc->capacity = 0;
}

//动态通讯录版本
void AddContact(Contact* pc)
{
assert(pc);
//增加容量
CheckCapacity(pc);
//增加信息
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 AddContact(Contact* pc)
//{
// assert(pc);
// if (pc->sz == MAX)
// {
// printf("通讯录已满,无法增加\n");
// 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("增加成功\n");
//
//}

void ShowContact(Contact* pc)
{
assert(pc);
int i = 0;
if (pc->sz == 0)
{
printf("通讯录为空,无需打印\n");
return;
}
printf("%-20s%-5s%-5s%-12s%-30s\n", "名字", "年龄", "性别", "电话", "地址");
for (i = 0; i < pc->sz; i++)
{
//打印每个人的信息
printf("%-20s%-5d%-5s%-12s%-30s\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[])
{
assert(pc);
int i = 0;
for (i = 0; i < pc->sz; i++)
{
if (strcmp(pc->data[i].name, name) == 0)
{
return i;
}
}
return -1;//找不到
}

void DelContact(Contact* pc)
{
char name[NAME_MAX];
assert(pc);
if (pc->sz == 0)
{
printf("通讯录为空,无法删除\n");
return;
}
printf("输入要删除的联系人的名字:");
scanf("%s", name);
//找到名字为name的人
int ret = FindByName(pc, name);
if (ret == -1)
{
printf("要删除的人不存在\n");
return;
}
//删除这个人
int i = 0;
for (i = ret; i < pc->sz - 1; i++)
{
pc->data[i] = pc->data[i + 1];
}
pc->sz--;
printf("删除成功\n");
}

void SearchContact(Contact* pc)
{
char name[NAME_MAX];
assert(pc);
printf("输入要查找的联系人的名字");
scanf("%s", name);
int ret = FindByName(pc, name);
if (ret == -1)
{
printf("查找的人不存在\n");
return;
}
//显示出来
printf("%-20s%-5s%-5s%-12s%-30s\n", "名字", "年龄", "性别", "电话", "地址");
printf("%-20s%-5d%-5s%-12s%-30s\n",
pc->data[ret].name, pc->data[ret].age, pc->data[ret].sex, pc->data[ret].tele, pc->data[ret].addr);
}

void ModifyContact(Contact* pc)
{
char name[NAME_MAX];
assert(pc);
printf("输入要修改的联系人的名字");
scanf("%s", name);
int ret = FindByName(pc, name);
if (ret == -1)
{
printf("修改的人不存在\n");
return;
}
//修改
printf("请输入名字:");
scanf("%s", pc->data[ret].name);
printf("请输入年龄:");
scanf("%d", &(pc->data[ret].age));
printf("请输入性别:");
scanf("%s", pc->data[ret].sex);
printf("请输入电话:");
scanf("%s", pc->data[ret].tele);
printf("请输入地址:");
scanf("%s", pc->data[ret].addr);
printf("修改成功 \n");

}

 下方是测试时的代码:
```#include "contact.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");
}

enum Option
{
    EXIT,
    ADD,
    DEL,
    SEARCH,
    MODIFY,
    SHOW,
    SORT
};


int main()
{
    int input = 0;
    //创建通讯录
    Contact con;//通讯录
    //初始化通讯录
    InitContact(&con);

    do
    {
        menu();
        printf("输入你的选择:");
        scanf("%d", &input);
        switch (input)
        {
        case ADD:
            AddContact(&con);
            break;
        case DEL:
            DelContact(&con);
            break;
        case SEARCH:
            SearchContact(&con);
            break;
        case MODIFY:
            ModifyContact(&con);
            break;
        case SHOW:
            ShowContact(&con);
            break;
        case SORT:
            break;
        case EXIT:
            DestroyContact(&con);
            printf("退出通讯录。\n");
            break;
        default:
            printf("输入错误,重新选择:");
        }
    } while (input);
    return 0;
}
目录
相关文章
|
存储 弹性计算 人工智能
2024阿里云开年采购优惠活动,云服务器99计划可领上云代金券
2024阿里云开年采购优惠活动,云服务器99计划可领上云代金券,2024年阿里云3月优惠「开年采购季」云服务器价格表和优惠券领取,99计划云服务器99元一年起、免费领取上云扶持优惠券,不只是云服务器、云数据库、存储、云电脑、域名等均有活动
|
7月前
|
前端开发 算法 Java
通义灵码2.0给人带来一种全新的开发辅助体验。
通义灵码2.0给人带来一种全新的开发辅助体验。
|
设计模式 数据可视化 测试技术
实践中的面向对象的例子
【7月更文挑战第1天】本文介绍面向对象编程注重代码的可理解性、重用和维护。例如,设计一个显示时间、温度等的设备,用户无需关心内部工作,这就是封装;如果需要多个设备,可通过多态创建不同实例;而继承则允许共享通用功能,如所有时钟都继承自计时器基类。
387 0
实践中的面向对象的例子
|
安全 Shell 网络安全
【内网安全-横向移动】WMI-WMIC命令&相关内网工具
【内网安全-横向移动】WMI-WMIC命令&相关内网工具
977 0
【内网安全-横向移动】WMI-WMIC命令&相关内网工具
|
存储 API
Revit API 修改项目文档中族参数的几个要点
Revit API 修改项目文档中族参数的几个要点
Revit API 修改项目文档中族参数的几个要点
|
程序员
这是我经历过最惨的转正答辩了
Hello 大家好,我是鸭血粉丝,试用期是每个刚入职的人都会经历的一段时间,时间不固定,少则一两月多则半年,具体的时间长短根据公司和个人表现不尽相同。而且试用期过后一般都会有一个转正答辩,这不阿粉最近就接到一个小伙伴的哭诉说转正答辩太难了,事情是这个样子的。
3355 0
这是我经历过最惨的转正答辩了
|
存储 Kubernetes 监控
k8s实战系列: 再谈为什么需要Kubernetes
k8s实战系列: 再谈为什么需要Kubernetes
k8s实战系列: 再谈为什么需要Kubernetes
|
Kubernetes 调度 Perl
k8s集群中让master也能运行pod,并且修改角色标签
k8s集群中让master也能运行pod,并且修改角色标签
702 0
|
存储 Hbase 分布式数据库
面向海量数据的极致成本优化-云HBase的一体化冷热分离
随着业务的持续发展,业务数据库存储量会持续增长。通常数据量过亿时,就需要考虑选择扩展能力更好的NOSQL数据库如HBase,足够满足大多数业务的存储需求。然而,对于大量存储瓶颈类业务,存储成本依然是系统设计中需要关注的重中之重,本文介绍了一种全新的冷热分离一体化方案,0改造成本实现业务冷热分离
5705 0
面向海量数据的极致成本优化-云HBase的一体化冷热分离
|
存储 NoSQL 大数据
表格存储TableStore2.0重磅发布,提供更强大数据管理能力
表格存储TableStore通过同时提供具象和抽象的数据模型,来满足不同核心数据场景的要求,更贴近业务抽象;提供多元化索引(全局二级索引和多元索引)来满足不同类型场景条件查询需求;提供全新的实时数据通道,来扩充实时计算的能力以及可自定义的实时数据处理。
4388 0