C语言实现通讯录 (附完整代码) 2

简介: C语言实现通讯录 (附完整代码)

🌼ShowContact

//显示所有联系人的信息
void ShowContact(const Contact* pc)//仅仅是显示,而不修改 所以用const限制修饰
{
  int i;
  for (i = 0; i < pc->sz; i++)
  {
    printf("姓名:%-20s\t", pc->data[i].name);//根据联系人结构体信息
    printf("年龄:%-4d\t", pc->data[i].age);
    printf("性别:%-5s\t", pc->data[i].sex);
    printf("电话:%-12s\t", pc->data[i].tele);
    printf("住址:%-13s\t", pc->data[i].addr);//统一左对齐
    printf("\n");
  }
}

但是,当显示的数据变多的时候,尽管是左对齐,还是不够美观。

接下来,我们采用打印标题的形式,更好的打印出数据。

//显示所有联系人的信息
void ShowContact(const Contact* pc)//仅仅是显示,而不修改 所以用const限制修饰
{
  int i;
  //打印列标题
  printf("%-20s\t%-4s\t%-5s\t%-12s\t%-30s\n", "名字", "年龄", "性别", "电话", "地址");
  //打印数据
  for (i = 0; i < pc->sz; i++)
  {
    printf("%-20s\t%-4d\t%-5s\t%-12s\t%-30s\t\n",
      pc->data[i].name,
      pc->data[i].age,
      pc->data[i].sex,
      pc->data[i].tele,
      pc->data[i].addr);
  }
}

🌼DelContact

//删除指定联系人
void DelContact(Contact* pc)
{
  int i = 0;
  char name[20];
  int pos = 0;
  int flag = 0;//输入要删除的人删除
  printf("请输入要删除人的名字:>");
  scanf("%s", name);//将要删除的人的名字放入name中(name本就是一个地址值)
  //查找有没有这个人
  for (i = 0; i < pc->sz; i ++)
  {
    if (strcmp(name, pc->data[i].name) == 0) //字符串比较函数
    {
      pos = i;//找到了,记下位置
      flag = 1;
    } 
  }
  if (flag == 0)
  {
    printf("要删除的人不存在\n");
    return;
  }
  //进行删除
  for (i = pos; i <pc->sz-1; i++)
  {
    pc->data[i] = pc->data[i + 1];
  }
  pc->sz--;
  printf("成功删除联系人!");
}

🌼进一步改进

当我们写后面的函数时,我们发现后面的查找函数 还是 修改函数 都需要像 删除函数一样 先在通讯录类进行查找。

为了更高效完成整个工程,提高效率,我们可以来写一个通过名字进行查找的函数FindByName

当我们写 删除 查找 修改函数时,首先可以直接调用这个函数。

int FindByName(Contact* pc, char name[])
{
  int flag = 0;
  int i = 0;
  int pos;
  for (i = 0; i < pc->sz; i++)
  {
    if (strcmp(name, pc->data[i].name) == 0) //字符串比较函数
    {
      pos = i;//找到了,记下位置
      return pos;
    }
  }
  if (flag == 0)
  {
    printf("要删除的人不存在\n");
    return -1;
  }
}

DelContact函数改进为:

//删除指定联系人
void DelContact(Contact* pc)
{
  int i = 0;
  char name[20];
  int pos = 0;
  int flag = 0;//输入要删除的人删除
  printf("请输入要删除人的名字:>");
  scanf("%s", name);//将要删除的人的名字放入name中(name本就是一个地址值)
  //查找有没有这个人
  if ((FindByName(pc, name) == -1))
  {
    printf("找不到要删除的联系人");
  }
  else
    pos = FindByName(pc, name); //记下位置
  //进行删除
  for (i = pos; i <pc->sz-1; i++)
  {
    pc->data[i] = pc->data[i + 1];
  }
  pc->sz--;
  printf("成功删除联系人!");
}

🌼SearchContact

//查找指定联系人
void SearchContact(const Contact* pc)
{
  int pos = 0;
  char name[20] = { 0 };
  printf("请输入要查找人的名字:>");
  scanf("%s", name);
  //查找有没有指定联系人
  if (FindByName(pc, name) == -1)
    printf("没有找到要查找的联系人\n");
  else
  {
    pos = FindByName(pc, name);
    printf("找到了!\n");
    printf("该联系人的下标为%d", pos);
    //打印数据
    printf("%-20s\t%-4s\t%-5s\t%-12s\t%-30s\n", "名字", "年龄", "性别", "电话", "地址");
    printf("%-20s\t%-4d\t%-5s\t%-12s\t%-30s\t\n",
      pc->data[pos].name,
      pc->data[pos].age,
      pc->data[pos].sex,
      pc->data[pos].tele,
      pc->data[pos].addr);
  }
}

🌼ModifyContact

//修改指定联系人
void ModifyContact(Contact* pc)
{
  int pos = 0;
  char name[20] = { 0 };
  printf("请输入要查找人的名字:>");
  scanf("%s", name);
  //查找有没有要修改的联系人
  if (FindByName(pc, name) == -1)
    printf("没有找到要修改的联系人\n");
  else 
  {
    printf("找到了要修改的联系人!\n");
    pos = FindByName(pc, name);
    //修改 (修改可以理解为再次录入一遍信息)
    printf("请输入名字:>");
    scanf("%s", pc->data[pos].name);
    printf("请输入年龄:>");
    scanf("%d", &(pc->data[pos].age));
    printf("请输入性别:>");
    scanf("%s", pc->data[pos].sex);
    printf("请输入电话:>");
    scanf("%s", pc->data[pos].tele);
    printf("请输入住址:>");
    scanf("%s", pc->data[pos].addr);
    printf("成功修改联系人!");
  }
}

🌼Sort Contact

//按照名字进行排序
//排序
int cmp_name(const void* p1, const void* p2)
{
  return strcmp(((PeoInfo*)p1)->name, ((PeoInfo*)p2)->name);
}
void SortContact(Contact* pc)
{
  int i = 0;
  //利用qsort 函数
  qsort(pc->data, pc->sz, sizeof((pc->data)[0]), cmp_name);
  //打印列标题
  printf("%-20s\t%-4s\t%-5s\t%-12s\t%-30s\n", "名字", "年龄", "性别", "电话", "地址");
  //打印数据
  for (i = 0; i < pc->sz; i++)
  {
    printf("%-20s\t%-4d\t%-5s\t%-12s\t%-30s\t\n",
      pc->data[i].name,
      pc->data[i].age,
      pc->data[i].sex,
      pc->data[i].tele,
      pc->data[i].addr);
  }
}

🎆🎆🎆完整代码

contact.h

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
#define MAX 100
//声明结构体--保存人的信息
typedef struct PeoInfo
{
  char name[20];
  int age;
  char sex[5];//一个汉字占两个字符
  char tele[12];
  char addr[30];
}PeoInfo;
//声明结构体通讯录
typedef struct Contact
{
  PeoInfo data[MAX];
  int sz;
}Contact;
int FindByName(Contact* pc, char name[]);
void AddContact(Contact* pc);
void ShowContact(const Contact* pc);
void DelContact(Contact* pc);
void SearchContact( Contact* pc);
void SearchContact(Contact* pc);
void SortContact(Contact* pc);
enum OPTION
{
  EXIT,//0
  ADD,//1
  DEL,//2
  SEARCH,//3
  MODIFY,//4
  SHOW,//5
  SORT//6
};
//函数的声明--初始化通讯录
void InitContact(Contact* pc);

contact.c

#include "contact.h"
void InitContact(Contact* pc)
{
  memset(pc->data, 0, sizeof(pc->data));
  pc->sz = 0;
}
//增加联系人的信息
void AddContact(Contact* pc)
{
  //判断数组是否可以增添?
  if (pc->sz == 100)
  {
    printf("通讯录已满,无法添加\n");
    return;
  }
  //通讯录没满
  else
  {
    printf("请输入名字:>");
    scanf("%s", pc->data[pc->sz].name);//pc->data 指向的是结构体数组 数组名本身就是地址,不用用取地址符号
    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("增加联系人成功!");
  }
}
//显示所有联系人的信息
void ShowContact(const Contact* pc)//仅仅是显示,而不修改 所以用const限制修饰
{
  int i;
  //打印列标题
  printf("%-20s\t%-4s\t%-5s\t%-12s\t%-30s\n", "名字", "年龄", "性别", "电话", "地址");
  //打印数据
  for (i = 0; i < pc->sz; i++)
  {
    printf("%-20s\t%-4d\t%-5s\t%-12s\t%-30s\t\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[])
{
  int flag = 0;
  int i = 0;
  int pos;
  for (i = 0; i < pc->sz; i++)
  {
    if (strcmp(name, pc->data[i].name) == 0) //字符串比较函数
    {
      pos = i;//找到了,记下位置
      return pos;
    }
  }
  if (flag == 0)
  {
    printf("要删除的人不存在\n");
    return -1;
  }
}
//删除指定联系人
void DelContact(Contact* pc)
{
  int i = 0;
  char name[20];
  int pos = 0;
  int flag = 0;//输入要删除的人删除
  printf("请输入要删除人的名字:>");
  scanf("%s", name);//将要删除的人的名字放入name中(name本就是一个地址值)
  //查找有没有这个人
  if ((FindByName(pc, name) == -1))
  {
    printf("找不到要删除的联系人");
  }
  else
    pos = FindByName(pc, name); //记下位置
  //进行删除
  for (i = pos; i <pc->sz-1; i++)
  {
    pc->data[i] = pc->data[i + 1];
  }
  pc->sz--;
  printf("成功删除联系人!");
}
//查找指定联系人
void SearchContact( Contact* pc)
{
  int pos = 0;
  char name[20] = { 0 };
  printf("请输入要查找人的名字:>");
  scanf("%s", name);
  //查找有没有指定联系人
  if (FindByName(pc, name) == -1)
    printf("没有找到要查找的联系人\n");
  else
  {
    pos = FindByName(pc, name);
    printf("找到了!\n");
    printf("该联系人的下标为%d", pos);
    //打印数据
    printf("%-20s\t%-4s\t%-5s\t%-12s\t%-30s\n", "名字", "年龄", "性别", "电话", "地址");
    printf("%-20s\t%-4d\t%-5s\t%-12s\t%-30s\t\n",
      pc->data[pos].name,
      pc->data[pos].age,
      pc->data[pos].sex,
      pc->data[pos].tele,
      pc->data[pos].addr);
  }
}
//修改指定联系人
void ModifyContact(Contact* pc)
{
  int pos = 0;
  char name[20] = { 0 };
  printf("请输入要查找人的名字:>");
  scanf("%s", name);
  //查找有没有要修改的联系人
  if (FindByName(pc, name) == -1)
    printf("没有找到要修改的联系人\n");
  else 
  {
    printf("找到了要修改的联系人!\n");
    pos = FindByName(pc, name);
    //修改 (修改可以理解为再次录入一遍信息)
    printf("请输入名字:>");
    scanf("%s", pc->data[pos].name);
    printf("请输入年龄:>");
    scanf("%d", &(pc->data[pos].age));
    printf("请输入性别:>");
    scanf("%s", pc->data[pos].sex);
    printf("请输入电话:>");
    scanf("%s", pc->data[pos].tele);
    printf("请输入住址:>");
    scanf("%s", pc->data[pos].addr);
    printf("成功修改联系人!");
  }
}
//按照名字进行排序
//排序
int cmp_name(const void* p1, const void* p2)
{
  return strcmp(((PeoInfo*)p1)->name, ((PeoInfo*)p2)->name);
}
void SortContact(Contact* pc)
{
  int i = 0;
  //利用qsort 函数
  qsort(pc->data, pc->sz, sizeof((pc->data)[0]), cmp_name);
  //打印列标题
  printf("%-20s\t%-4s\t%-5s\t%-12s\t%-30s\n", "名字", "年龄", "性别", "电话", "地址");
  //打印数据
  for (i = 0; i < pc->sz; i++)
  {
    printf("%-20s\t%-4d\t%-5s\t%-12s\t%-30s\t\n",
      pc->data[i].name,
      pc->data[i].age,
      pc->data[i].sex,
      pc->data[i].tele,
      pc->data[i].addr);
  }
}

test.c

#include"contact.h"
void menu()
{
  printf("\n");
  printf("******************\n");
  printf("******请选择******\n");
  printf("******1.增添******\n");
  printf("******2.删除******\n");
  printf("******3.查找******\n");
  printf("******4.修改******\n");
  printf("******5.显示******\n");
  printf("******6.排序******\n");
  printf("******0.退出******\n");
}
void test()
{
  Contact con;  //定义结构体变量-通讯录
  InitContact(&con);//对通讯录进行初始化
  int input = 0;
  do
  {
    menu();
    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:
      SortContact(&con);
      break;
    case EXIT:
      printf("退出通讯录\n");
      break;
    default:
      printf("选择错误,重新选择\n");
      break;
    }
  } while (input);
}
int main()
{
  test();
  return 0;
}


相关文章
|
13天前
|
C语言
C语言进阶第八课 --------通讯录的实现
C语言进阶第八课 --------通讯录的实现
|
14天前
|
传感器 算法 C语言
C语言在嵌入式系统开发中的优化策略与代码实现
C语言在嵌入式系统开发中的优化策略与代码实现
26 1
|
18天前
|
存储 算法 C语言
C语言进阶:顺序表(数据结构基础) (以通讯录项目为代码练习)
C语言进阶:顺序表(数据结构基础) (以通讯录项目为代码练习)
|
18天前
|
编译器 Linux C语言
C语言:预处理详解(知识点和代码演示)
C语言:预处理详解(知识点和代码演示)
|
18天前
|
C语言
换硬币问题(C语言代码练习)
换硬币问题(C语言代码练习)
|
21天前
|
C语言
以c语言为基础实现的简易扫雷游戏(游戏代码附在文章最后,如有需要请自取)
以c语言为基础实现的简易扫雷游戏(游戏代码附在文章最后,如有需要请自取)
44 1
|
27天前
通讯录(C语言版)
通讯录(C语言版)
|
28天前
|
编译器 C语言 C++
c语言中代码运行时发生c++弹窗的解决方法
通过遵循这些步骤,你应该能够解决在C语言代码运行时出现C++弹窗的问题,确保代码在纯C环境中运行。 买CN2云服务器,免备案服务器,高防服务器,就选蓝易云。百度搜索:蓝易云
19 0
|
1月前
费马螺线在现实生活中的应用
费马螺线在现实生活中的应用
12 1
|
1月前
|
数据采集 算法 数据挖掘
Chameleon算法的C语言实现及代码解析
以上是Chameleon算法的简要C语言实现及代码解析。实际的算法涉及较多细节和复杂计算,这里只是一个基本的框架,实际使用中还需要完善算法的各个细节部分。
30 6