C实现通讯录~多版本(静态和动态)

此通讯录可以实现增删查改和打印数据,目前还不能进行保存,没有使用文件,此通讯录现有两个版本,一个是静态的另一个是动态的,静态的直接申请了一千个存储,占用内存太大不方便,动态的通讯录刚开始是有三个可用内存,当占用的内存和最大内存相等时会自动realloc每次增加两个。

代码的运行在最后面~~~

可能还有一些不完整的地方,如果各位大佬发现的话可以提出来。

头文件Contact.h

#pragma once

 

 

#include<string.h>

#include<stdio.h>

#include<stdlib.h>

#define MAX_NAME 20

#define MAX_SEX 10

#define MAX_TELE 12

#define MAX_ADDER 30

#define MAX_AGE 10

#define MAX 1000

#define DEFAULT_sz 3

#define INC_sz 2

//定义结构体类型

typedef struct PeoInfo

{

 char name[MAX_NAME];

 char sex[MAX_SEX];

 char age[MAX_AGE];

 char tele[MAX_TELE];

 char adder[MAX_ADDER];

}PeoInfo;

//通讯录-静态版本

//typedef struct Contact

//{

// PeoInfo data[MAX];//存放添加进来人的信息

// int sz;//记录当前通讯录中的信息个数

//}Contact;

 

//通讯录动态版本

typedef struct Contact

{

 PeoInfo* data;//指向动态申请的空间,用来存放联系人的信息

 int sz;//记录当前通讯录中的信息个数

 int capacity;//记录当前通讯录最大容量

}Contact;

 

void IntiContact(Contact* pc);

//增加联系人

void AddContact(Contact* pc);

//打印联系人信息

void printContact(const Contact*pc);

//删除联系人

void DelContact(Contact* pc);

//查找联系人

void SearContact(Contact* pc);

//修改联系人

void ModifyContact(Contact* pc);

//排序通讯录

void SortContact(Contact* pc);

//销毁通讯录

void DestoryContact(Contact* pc);

函数实现Contact.c

#define _CRT_SECURE_NO_WARNINGS 

#include<stdio.h>

#include "contact.h"

#include<string.h>

//静态版本

//void IntiContact(Contact* pc)

//{

// pc->sz = 0;

// //memset(); 内存设置

// memset(pc->data, 0, sizeof(pc->data));

//}

 

//动态版本

void IntiContact(Contact* pc)

{

 pc->data = malloc(DEFAULT_sz * sizeof(PeoInfo));

 if (pc->data == NULL)

 {

  perror("IntContact");

 }

 pc->sz = 0;//初始化后默认是0

 pc->capacity = DEFAULT_sz;

 //memset(); 内存设置

 memset(pc->data, 0, sizeof(pc->data));

}

 

//销毁通讯录

void DestoryContact(Contact* pc)

{

 free(pc->data);

 pc->data = NULL;

 pc->sz = 0;

 pc->capacity = 0;

 

}

 

//静态版本的增加联系人

//void Addcontact(Contact* pc)

//{

// if (pc->sz == MAX)

// {

// printf("通讯录已满,无法添加");

// return;

// }

静态版本的增加联系人

// //增加一个人的信息

// printf("请输入名字:>");

// scanf("%s", pc->data[pc->sz].name);

// printf("请输入年龄:>");

// scanf("%s", 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].adder);

//}

 

//动态版本的增加联系人

 void AddContact(Contact * pc)

{

  //考虑增容

  if (pc->sz == pc->capacity)

  {

   PeoInfo*ptr=(PeoInfo*)realloc(pc->data, (pc->capacity + INC_sz) * sizeof(PeoInfo));

   if (ptr != NULL)

   {

    pc->data = ptr;

    pc->capacity += INC_sz;

    printf("增容成功");

   }

   else

   {

    perror("addContact");

    printf("增加联系人失败");

    return;

   }

  }

 //增加一个人的信息

 printf("请输入名字:>");

 scanf("%s", pc->data[pc->sz].name);

 printf("请输入年龄:>");

 scanf("%s", 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].adder);

 pc->sz++;

 printf("增加成功");

}

 

 

void printContact(const Contact* pc)

{

 int i = 0;

 //打印标题

 printf("%-20s\t %-5s\t %-5s\t %-12s\t %-20s\t","名字","年龄","性别","电话","地址");

 printf("\n");

 for (int i = 0; i < pc->sz; i++)

 {

  printf("%-20s\t %-5s\t %-5s\t %-12s\t %-20s\t",

                           pc->data[i].name,

                               pc->data[i].age,

                            pc->data[i].sex,

                           pc->data[i].tele,

                            pc->data[i].adder);

 }

}

//查找联系人

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;

}

 

//删除联系人

void DelContact(Contact* pc)

{

 char name[MAX_NAME] = { 0 };

 if (pc->sz == 0)

 {

  printf("通讯录为空");

  return;

 }

 printf("请输入要删除人的名字");

 scanf("%s",name);

 //1.查找要删除的联系人

 //有/没有

 int pos = FindByName(pc, name);

 if (pos == -1)

 {

  printf("要删除的人不存在");

  return;

 }

 

 //2.删除

 int i = 0;

 for (i = pos; i <= pc->sz-1; i++)

 {

  pc->data[i] = pc->data[i + 1];

 }

 pc->sz--;

 printf("删除成功");

}

//查找联系人

void SearContact(Contact* pc)

{

 char name[MAX_NAME] = { 0 };

 printf("请输入要查找人的名字");

 scanf("%s", name);

 int pos = FindByName(pc, name);

 if (pos == -1)

 {

  printf("要查找的人不存在");

  return;

 }

 else

 {

  printf("%-20s\t %-5s\t %-5s\t %-12s\t %-20s\t", "名字", "年龄", "性别", "电话", "地址");

  for (int i = 0; i < pc->sz; i++)

  {

   //打印数据

   printf("%-20s\t %-5s\t %-5s\t %-12s\t %-20s\t",

    pc->data[pos].name,

    pc->data[pos].age,

    pc->data[pos].sex,

    pc->data[pos].tele,

    pc->data[pos].addr);

  }

 }

}

 

//修改联系人

void ModifyContact(Contact * pc)

{

 char name[MAX_NAME] = { 0 };

 printf("请输入要修改人的名字");

 scanf("%s", name);

 int pos = FindByName(pc, name);

 if (pos == -1)

 {

  printf("要修改的人不存在");

  return;

 }

 else

 {

  printf("请输入名字:>");

  scanf("%s", pc->data[pc->sz].name);

  printf("请输入年龄:>");

  scanf("%s", 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].adder);

  printf("修改成功");

 }

 

}

 

//排序通讯录

void SortContact(Contact* pc)

{

 

}

 

 

 

测试类test.c

#define _CRT_SECURE_NO_WARNINGS 

#include<stdio.h>

#include"contact.h"

 

//通讯录

// 静态版本

//1.能够存放1000个人的信息

//每个人的信息

//名字,年龄,性别,电话,地址

//2.增加个人信息

//3.删除人的信息

//4.修改人的信息

//5.查找人的信息

//6。排序通讯录信息

//

//版本2

//动态增长版本

//1.>通讯录初始化后能存放3个人的信息

//2。当我们空间放满后增加2个人的信息

//3+2

void menu()

{

 printf("*********************\n");

    printf("**1.add 2.del**\n");

 printf("**3.search 4.modify**\n");

 printf("***5.sort 6.print****\n");

 printf("*******0.exit********\n");

 printf("*********************\n");

}

enum Option

{

 EXIT,

 ADD,

 DEL,

 SEARCH,

 MODIFY,

    SORT,

 PRINT

};

int main()

{

 int input = 0;

 //创建通讯录

 Contact con;

 //初始化通讯录

 //给data申请一块连续的空间在堆上

 //sz=0

 //capacity 初始化为当前的最大容量

 IntiContact(&con);

 

 do

 {

  menu();

     printf("请选择:>");

  scanf("%d", &input);

  switch (input)

  {

  case ADD:

   //增加人的欣喜

   AddContact(&con);

   break;

  case DEL:

   //删除

   DelContact(&con);

   break;

  case SEARCH:

   SearContact(&con);

   break;

  case MODIFY:

   ModifyContact(&con);

   break;

  case SORT:

   SortContact(&con);

      break;

  case PRINT:

   printContact(&con);

   break;

  //销毁通讯录

  case EXIT:

   DestoryContact(&con);

    printf("退出通讯录");

   break;

  default:

   printf("选择错误,请重新选择");

   break;

  }

 } while (input);

 

 return 0;

}72720513896d472f81c25d4fa686c75b.png

 2481d894fe4648839b728cc4d1be7f00.png

15dd726282cf449fb1d8282423faa779.png 

 

 

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Naxx Crazy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值