通讯录实现

简介: 通讯录实现

下方是头文件的代码

#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;
}
目录
相关文章
|
7月前
简易实现通讯录(2.0)
简易实现通讯录(2.0)
22 0
|
7月前
简易实现通讯录(1.0)
简易实现通讯录(1.0)
19 0
|
4天前
|
数据管理
【通讯录项目 (3 / 3)】基于顺序表的通讯录实现——通讯录项目实现
通讯录项目我们实现了大部分内容,接下来你可以自行探索,丰富功能。
9 0
|
4天前
|
C语言
【通讯录项目 (2 / 3)】基于顺序表的通讯录实现——顺序表功能实现
顺序表的功能我们已经实现,我们使用的是最简单的顺序表,所以整个过程看起来没有困难。在下一篇文章中我们将进行通讯录的实现。 在通讯录里,顺序表的类型不在是简单的" int ",而是结构体类型。 下面给出通讯录的基本功能供大家参考预习。
14 0
|
4天前
|
存储 算法
|
9月前
|
C语言
【纯C实现简易通讯录】
【纯C实现简易通讯录】
33 0
|
10月前
|
存储
通讯录实现上
通讯录实现上
通讯录实现上
|
5月前
|
存储 Java C++
通讯录的实现
通讯录的实现
41 0
|
6月前
|
C++
简易通讯录的实现(上)
简易通讯录的实现(上)
20 0
|
6月前
简易通讯录的实现(下)
简易通讯录的实现(下)
22 0