动态通讯录

简介: 动态通讯录

contact.h


#pragma once
#include <string.h>
#include <stdio.h>
#include <assert.h>
#include <stdlib.h>
#define MAX 1000
#define NAME_MAX 20
#define SEX_MAX 5
#define SEX_MAX 12
#define ADDR_MAX 30
//通讯录初始状态的容量大小
#define DEFAULT_SZ 3 
//类型的声明
typedef struct PeoInfo    //  一个人的信息
{
  char name[NAME_MAX];
  char sex[SEX_MAX];
  int age;
  char tele[SEX_MAX];
  char addr[ADDR_MAX];
}PeoInfo;
enum Option   //选则
{
  EXIT, //0
  ADD,  //1
  DEL,  //2
  SEARCH,
  MODIFY,
  SORT,
  PRINT
};
//静态版本
//typedef struct Contact
//{
//  PeoInfo data[1000];
//  int sz;     //记录已经保存的信息个数
//
//}Contact;
//动态版本
typedef struct Contact
{
  PeoInfo* data;
  int sz;     //记录已经保存的信息个数
  int capacity; //记录通讯录当前最大容量
}Contact;
//    函数的声明
//通讯录初始化
void InitContact(Contact* pc);
//添加联系人信息 改变con
void AddContact(Contact* pc);
//打印信息
void PrintContact(const Contact* pc);  //不希望修改
// 删除指定联系人
void DelContact(const Contact* pc);
//查找联系人
void SearchContact(const Contact* pc);
//销毁通讯录
void DestroyContact(const Contact* pc);


contact.c


#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"
//找到返回下标 找不到返回负一
int FindByName(const Contact* pc, char name[])
{
  assert(pc);
  int i = 0;
  for (i = 0; i < pc->sz; i++)
  {
    if (0 == strcmp(pc->data[i].name, name))  //用 strcmp 比较 相等返回下标
    {
      return i;
    }
  }
  return -1;    
}
//静态版本
//void InitContact(Contact* pc)
//{
//  assert(pc);   //因为我们要用很多次指针所以要  断言一下
//  pc->sz = 0;
//  memset(pc->data, 0, sizeof(pc->data) ); //data初始化 data全整成零
//
//}
//动态版本
void InitContact(Contact* pc)
{
  assert(pc);   //因为我们要用很多次指针所以要  断言一下
  pc->sz = 0;
  pc->capacity = DEFAULT_SZ;
  pc->data = (PeoInfo*)malloc(pc->capacity * sizeof(PeoInfo));
  if (pc->data == NULL)
  {
    perror("InitContact::malloc");
    return 1;
  }
  memset(pc->data, 0, pc->capacity * sizeof(PeoInfo));
}
void CheckCapacity(Contact* pc)
{
  if (pc->capacity == pc->data)
  {
    PeoInfo* tmp = (PeoInfo*)realloc(pc->data, (pc->capacity + 2) * sizeof(PeoInfo));
    if (tmp != NULL)
    {
      pc->data = tmp;
    }
    else
    {
      perror("CheckCapacity::realloc");
      return;
    }
  }
  pc->capacity += 2;
  printf("\n增容成功!\n");
}
void DestroyContact(Contact* pc)
{
  free(pc->data);
  pc->data = NULL;
  pc->capacity = 0;
  pc->sz = 0;
  printf("销毁成功!");
}
void AddContact(Contact* pc)
{
  assert(pc);
  //静态版本
  //if (pc->sz == MAX)
  //{
  //  printf("通讯录以满,无法添加\n");
  //  return;
  //}
  //动态版本
  //增容代码
  CheckCapacity(pc);
  // 录入信息   利用sz 与 data 的下标关系
  printf("请输入名字:>");
  scanf("%s", pc->data[pc->sz].name);
  printf("请输入年龄:>");
  scanf("%d", &(pc->data[pc->sz].age)); // 注意加&
  printf("请输入电话:>");
  scanf("%d", pc->data[pc->sz].tele);
  printf("请输入地址:>");
  scanf("%s", pc->data[pc->sz].addr);
  pc->sz++; //利用sz 与 data 的下标关系 0对应data下标1,1对应data下标2
  printf("添加成功\n");
}
void PrintContact(const Contact* pc)  //不希望修改
{
  assert(pc);
  printf("%-20s%-5s%-5s%-12s%-30s\n", "姓名", "年龄", "性别", "电话", "地址");
  int i = 0;
  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);
  } //左对齐加符号
}
void DelContact(Contact* pc)
{
  assert(pc);
  if (pc->sz == 0)
  {
    printf("通讯录已空,无法删除\n");
    return;
  }
  //删除
  //1. 找到
  char name[NAME_MAX] = { 0 };
  printf("请输入要删除人的名字:>");
  scanf("%s", name);
  int pos = FindByName(pc, name);
  if (pos == -1)
  {
    printf("要删除的人不存在\n");
    return;
  }
  //2. 删除 依次往前覆盖
  int j = 0;
  for (j = pos; j < pc->sz - 1; j++)
  {
    pc->data[j] = pc->data[j + 1];
  }
  pc->sz--;
  printf("删除成功\n");
}
void SearchContact(const Contact* pc)
{
  char name[NAME_MAX] = { 0 };
  printf("请输入要查找人的名字:>");
  scanf("%s", name);
  int pos = FindByName(pc, name);
  if (pos == -1)
  {
    printf("要查找的人不存在\n");
    return;
  }
  printf("%-20s %-5s %-5s %-12s %-30s\n", "姓名", "年龄", "性别", "电话", "地址");
  printf("%-20s %-5d %-5s %-12s %-30s\n", pc->data[pos].name, pc->data[pos].age, pc->data[pos].sex,
    pc->data[pos].tele, pc->data[pos].addr);
}


test.c


#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"
//1.保存 1000 人联系人信息
//2.增添,删除联系人
//3.修改联系人
//4.查找联系人
//5.排序联系人
void menu()
{
  printf("******************************\n");
  printf("****** 1.Add     2.del    ****\n");
  printf("****** 3.search  4.moidfy ****\n");
  printf("****** 5.sort    6.print  ****\n");
  printf("****** 0.exit             ****\n");
}
void test()
{
  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:
      break;
    case SORT:
      break;
    case PRINT:
      PrintContact(&con);
      break;
    case EXIT:
      printf("退出通讯录\n");
      void DestroyContact(const Contact * pc)
      break;
    default:
      printf("选择错误\n");
    }
  } 
  while (input);
}
int main(input)
{
  test(); 
  return 0;
}


相关文章
|
存储 XML NoSQL
提高代码质量,避免内存泄漏:深入探索Valgrind工具
提高代码质量,避免内存泄漏:深入探索Valgrind工具
|
弹性计算 Ubuntu Unix
阿里云服务器镜像系统怎么选?云服务器操作系统选择攻略
阿里云服务器镜像是什么?云服务器系统镜像怎么选择?阿里云百科以Web网站应用为例,常见的Web程序语言如PHP,PHP语言经典环境为LAMP或LNMP,建议选择Linux类操作系统,如CentOS Stream、Alibaba Cloud Linux等,另外如PERL、CGI、数据库MySQL、SQLite建议选择Linux镜像;如果是ASP/.NET,云服务器镜像建议选择Windows Server操作系统,如果是Access数据库,肯定也是要选择Windows Server镜像。
3291 0
阿里云服务器镜像系统怎么选?云服务器操作系统选择攻略
|
SQL 关系型数据库 分布式数据库
|
机器学习/深度学习 人工智能 自然语言处理
软件测试中的人工智能革命
本文探讨了人工智能在软件测试中的应用,包括自动化测试、智能缺陷检测和测试用例生成。通过实际案例分析,展示了AI如何提高测试效率和准确性,并讨论了未来发展趋势。
216 9
|
数据管理 BI
自动上架,助力高效资产管理和运营
Dataphin推出的资产自动上架功能,旨在解决资产运营人员手动维护和上架大量资产的繁琐工作。支持不同类型的规则配置,并提供灵活的执行配置和排序功能,从而高效管理不同特性的资产,也能有效避免冲突,助力提升工作效率,为资产运营提供了更多可能性。
323 10
|
存储 NoSQL Java
Java 使用 Redis
10月更文挑战第22天
284 0
|
Apache 数据中心 Windows
将网站迁移到阿里云Windows系统云服务器,访问该站点提示连接被拒绝,如何处理?
将网站迁移到阿里云Windows系统云服务器,访问该站点提示连接被拒绝,如何处理?
|
SQL 存储 Java
Spring Boot中的数据迁移策略
Spring Boot中的数据迁移策略
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的校园二手物品交易平台的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue+uniapp的校园二手物品交易平台的详细设计和实现(源码+lw+部署文档+讲解等)
375 2
|
安全 Python
全局代理IP的工作原理和实现方法
全局代理IP的工作原理和实现方法
379 7