通讯录【一】静态版本

简介: 通讯录【一】静态版本

目录

概况

完整代码:

Contact.h     结构体和函数的声明,以及头文件的引用

text.c     通讯录的菜单以及主函数

Contact.c     通讯录各种功能函数的实现  


概况

采用C语言来模拟编写一个静态通讯录,就是说输入的内容不能保存下来。

其中主要包含了六大块内容:

联系人的添加

联系人的删除

联系人的查找

联系人的修改

联系人的展示

联系人的排序


完整代码:

首先,我将通讯录分成了三个部分:


1、text.c                   //通讯录的菜单以及主函数


2、Contact.h             //结构体和函数的声明,以及头文件的引用


3、Contact.c              //通讯录各种功能函数的实现        


Contact.h     结构体和函数的声明,以及头文件的引用

#pragma once
#include<stdio.h>
#include<string.h>
#include<assert.h>
#include<stdlib.h>
#define MAX_NAME 20
#define MAX_SEX 5
#define MAX_TELE 20
#define MAX_ADDR 30
#define MAX 100
#define _CRT_SECURE_NO_WARNINGS 1
//表示一个人的信息
struct PeoInfo
{
  char name[MAX_NAME];  //姓名
  char sex[MAX_SEX];    //性别
  char tele[MAX_TELE];  //电话
  int age;              //年龄
  char addr[MAX_ADDR];  //住址
};
struct Contact
{
  struct PeoInfo data[MAX];
  int sz ;      //表示通讯录中还没有信息
};
//初始化通讯录
void InitContact(struct Contact* pc);
//给通讯录添加联系人
void AddContact(struct Contact* pc);
//显示通讯录的信息
void ShowContact(const struct Contact* pc);
//删除指定联系人
void DelContact(struct Contact* pc);
//查找指定联系人
void SearchContact(const struct Contact* pc);
//修改指定联系人
void ModifyContact(struct Contact* pc);
//排序通讯录
void SortContact(struct Contact* pc);

text.c     通讯录的菜单以及主函数

#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");
}
int main()
{
  int input = 0;
  //创建通讯录
  struct Contact con;//存放通讯录数据
  //初始化通讯录
  InitContact(&con);
  do
  {
    menu();
    printf("请选择>:");
    scanf("%d", &input);
    switch(input)
    {
    case 1:
      AddContact(&con);
      break;
    case 2:
      DelContact(&con);
      break;
    case 3:
      SearchContact(&con);
      break;
    case 4:
      ModifyContact(&con);
      break;
    case 5:
      ShowContact(&con); 
      break;
    case 6:
      SortContact(&con);
      break;
    case 0:
      printf("退出通讯录\n");
      break;
    default:
      printf("选择错误,请重新输入\n");
      break;
    }
  } while (input);
  return 0;
}

Contact.c     通讯录各种功能函数的实现  

#include"Contact.h"
void InitContact(struct Contact* pc)
{
  assert(pc);//防止pc是空指针
  pc->sz = 0;
  memset(pc->data, 0, 100 * sizeof(struct PeoInfo));//将pc->里面的100数据的字节数全部赋为0
}
void AddContact(struct Contact* 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");
}
void ShowContact(struct Contact* pc)
{
  int i = 0;
  printf("%-20s\t%-5s\t%-5s\t%-20s\t%-30s\n", "姓名", "性别", "年龄", "电话", "地址");
  for (i = 0; i < pc->sz; i++)
  {
    printf("%-20s\t%-5s\t%-5d\t%-20s\t%-30s\n", pc->data[i].name,
      pc->data[i].sex,
      pc->data[i].age,
      pc->data[i].tele,
      pc->data[i].addr); 
  } 
}
//这里的static表示该函数只能在所在的源文件中使用,其他文件不能使用
static int FindByName(const struct Contact* pc, char name[])
{
  int i = 0;
  for (i = 0; i < pc->sz; i++)
  {
    if (0 == strcmp(pc->data[i].name, name))
    {
      return i;
    }
  }
  return -1;
}
void DelContact(struct Contact* pc)
{
  char name[MAX_NAME];
  printf("请输入你想要删除人的姓名:>");
  scanf("%s", name);
  int ret = FindByName(pc, name);
  if (ret == -1)
  {
    printf("要删除的人不存在\n");
  }
  else
  {
    //删除
    int j = 0;
    for (j = ret; j < pc->sz - 1; j++)
    {
      pc->data[j] = pc->data[j + 1];
    }
    pc->sz--;
    printf("成功删除指定联系人\n");
  }
}
void SearchContact(const struct Contact* pc)
{
  char name[MAX_NAME];
  printf("请输入你想要查找人的姓名:>");
  scanf("%s", name);
  //查找一下指定联系人是否存在
  int ret = FindByName(pc, name);
  if (ret == -1)
  {
    printf("要查找的人不存在\n");
  }
  else
  {
    printf("%-20s\t%-5s\t%-5s\t%-20s\t%-30s\n", "姓名", "性别", "年龄", "电话", "地址");
      printf("%-20s\t%-5s\t%-5d\t%-20s\t%-30s\n", pc->data[ret].name,
        pc->data[ret].sex,
        pc->data[ret].age,
        pc->data[ret].tele,
        pc->data[ret].addr);
  }
}
void ModifyContact(struct Contact* pc)
{
  printf("请输入想要修改人的名字:>");
    char name[MAX_NAME];
    scanf ("%s", name);
    int ret = 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");
    }
}
//按照年龄来排序
//int CmpByAge(const void* e1, void* e2)
//{
//  return ((struct PeoInfo*)e1)->age - ((struct PeoInfo*)e2)->age;
//}
//按照名字排序
int CmpByName(const void* e1, void* e2)
{
  return strcmp(((struct PeoInfo*)e1)->name , ((struct PeoInfo*)e2)->name);
}
void SortContact(struct Contact* pc)
{
  qsort(pc->data, pc->sz, sizeof(struct PeoInfo), CmpByName);
}


相关文章
|
网络协议 安全 网络安全
常见的网络传输协议有几种
常见的网络传输协议涵盖多个层次,包括传输层(如TCP、UDP、SCTP)、应用层(如HTTP/HTTPS、FTP、SMTP、DNS、SSH)、网络层(如IP、ICMP、ARP)、数据链路层(如Ethernet、PPP、Wi-Fi)及安全协议(如SSL/TLS、IPSec)。这些协议各具特色,适用于不同场景,如TCP用于可靠传输,UDP适合实时应用,而HTTP/HTTPS则服务于网页浏览和数据交换。通过这些协议的协同工作,现代互联网和局域网得以实现多样化的应用和服务。
|
人工智能 自然语言处理 Linux
|
机器学习/深度学习 边缘计算 计算机视觉
基于深度学习的图像识别优化技术研究
【5月更文挑战第5天】 在当前的计算机视觉领域,图像识别技术已取得显著进展,尤其是深度学习方法的广泛应用。然而,随着数据量的日益增加和模型复杂度的提升,如何提高图像识别的效率与准确性成为新的挑战。本文提出了一种基于改进卷积神经网络(CNN)的图像识别优化技术,旨在减少模型参数量、加速推理过程,并保持甚至提升识别精度。通过引入深度可分离卷积、注意力机制以及量化剪枝策略,该技术在多个标准数据集上显示出了卓越的性能。
|
弹性计算 Ubuntu Linux
10秒,2024年阿里云搭建幻兽帕鲁服务器教程
如何自建幻兽帕鲁服务器?基于阿里云服务器搭建幻兽帕鲁palworld服务器教程来了,一看就懂系列。本文是利用OOS中幻兽帕鲁扩展程序来一键部署幻兽帕鲁服务器。
|
安全 网络安全 数据安全/隐私保护
|
XML 开发工具 C++
强强联手!VS Code让它成为最强流程图工具
自从切换到mac之后,我一直在寻找一款趁手的流程图工具。遇到draw.io之后,我被这款工具的跨平台,适用场景广泛所吸引。直到它与vs code强强结合,使得它一举奠定在我心中最为优秀的流程图工具。本文就来介绍一款这款让人赞不绝口的流程图工具。
强强联手!VS Code让它成为最强流程图工具
|
前端开发
lodash两数相减
lodash两数相减
203 0
|
IDE 测试技术 开发工具
一个方法帮你在正式脚本里添加“子脚本”的运行
一个方法帮你在正式脚本里添加“子脚本”的运行
337 0
|
消息中间件 Java Kafka