【C语言】—— 通讯录

简介: 【C语言】—— 通讯录

一、基本思路及功能介绍


       想要用C语言实现通讯录的功能,基本上涵概了C语言入门的一些知识运用,如:指针、结构体、文件操作、动态内存管理等相关的知识;

实现一个简单的通讯录的基本功能:

1.添加联系人信息;


       2.删除联系人信息;


       3.查找联系人信息;


       4.修改联系人信息;


       5.显示联系人信息;


       6.排序联系人信息;  


       7.保存联系人信息;


       8.退出通讯录;

二、功能实现

1.基础菜单的实现

void menu()
{
  printf("\t\t\t\t**********************************\n");
  printf("\t\t\t\t******    通讯录管理系统    *******\n");
  printf("\t\t\t\t**********************************\n");
  printf("\t\t\t\t*      1.添加联系人---ADD         *\n");
  printf("\t\t\t\t*      2.删除联系人---DEL         *\n");
  printf("\t\t\t\t*      3.查找联系人---SEARCH      *\n");
  printf("\t\t\t\t*      4.修改联系人---MODIFY      *\n");
  printf("\t\t\t\t*      5.显示联系人---SHOW        *\n");
  printf("\t\t\t\t*      6.排序联系人---SORT        *\n");
  printf("\t\t\t\t*      0.退出通讯录---EXIT        *\n");
  printf("\t\t\t\t**********************************\n");
  printf("\t\t\t\t**********************************\n");
}
enum
{
  EXIT,
  ADD,
  DEL,
  SEARCH,
  MODIFY,
  SHOW,
  SORT
};
int main() 
{
  int input = 0;
  do
  {
    menu();
    printf("请输入:>");
    scanf("%d", &input);
    switch (input)
    {
    case ADD:
      break;
    case DEL:
      break;
    case SEARCH:
      break;
    case MODIFY:
      break;
    case SHOW:
      break;
    case SORT:
      break;
    case EXIT:
      printf("退出通讯录\n");
      break;
    default:
      printf("选择错误,请重新选择\n");
      break;
    }
  } while (input);
  return 0;
}

2.如何创建通讯录及所有函数功能

注意点:

       通讯录的容量应该随着我们存储的联系人个数去增长,让系统自动分配,既不会过多也不会过少;

#define NAME_MAX 20
#define SEX_MAX 20
#define TELE_MAX 20
#define ADDR_MAX 20
struct PeoInfo
{
  char name[NAME_MAX];//姓名
  int age;      //年龄
  char sex[SEX_MAX];  //性别
  char tele[TELE_MAX];//电话
  char addr[ADDR_MAX];//住址
};
struct Contact
{
  struct PeoInfo* data;//能够动态存储联系人的信息
  int sz;        //记录当前联系人的个数
  int capacity;    //记录当前通讯录的容量
};
//初始化通讯录
void InitContact(struct Contact* pc);
//添加联系人信息
void AddContact(struct Contact* pc);
//销毁通讯录信息
void DistroyContact(struct Contact* pc);
//显示联系人信息
void ShowContact(struct Contact* pc);
//删除联系人信息
void DelContact(struct Contact* pc);
//查找联系人信息
void SearchContact(struct Contact* pc);
//修改联系人信息
void ModifyContact(struct Contact* pc);
//排序联系人信息
void SortContact(struct Contact* pc);
//加载有效信息到通讯录中
void LoadContact(struct Contact* pc);
//保存信息
void SaveContact(struct Contact* pc);

3.添加联系人信息功能实现

#define NAME_MAX 20
#define SEX_MAX 20
#define TELE_MAX 20
#define ADDR_MAX 20
#define DEFAULT_SZ 3
//扩充容量
void CheckContact(struct Contact* pc)
{
  if (pc->sz == pc->capacity)
  {
    struct PeoInfo* ptr = (struct PeoInfo*)realloc(pc->data, (pc->capacity + 2) * sizeof(struct PeoInfo));
    if (ptr != NULL)
    {
      pc->data = ptr;
      pc->capacity += 2;
      printf("扩容成功\n");
    }
    else
    {
      printf("扩容失败\n");
      exit(1);
    }
  }
}
//初始化通讯录
void InitContact(struct Contact* pc)
{
  pc->sz = 0;
  pc->data = (struct PeoInfo*)malloc(DEFAULT_SZ * sizeof(struct PeoInfo));
  pc->capacity = DEFAULT_SZ;
}
//添加联系人信息
void AddContact(struct Contact* pc)
{
  CheckContact(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);
  printf("添加成功\n");
  pc->sz++;
}

4.显示联系人信息功能实现

//显示联系人信息
void ShowContact(struct Contact* pc)
{
  if (pc->sz == 0)
  {
    printf("通讯录为空,显示失败!!!\n");
    return;
  }
  int i = 0;
  printf("\t\t--------------------------------------------------------------------------\n");
  printf("\t\t--------------------------------------------------------------------------\n");
  printf("\t%15s\t%15s\t%15s\t%15s\t%15s\n\n",
    "姓名", "年龄", "性别", "电话", "住址");
  for (i = 0; i < pc->sz; i++)
  {
    printf("\t%15s\t%15d\t%15s\t%15s\t%15s\n",
      pc->data[i].name,
      pc->data[i].age,
      pc->data[i].sex,
      pc->data[i].tele,
      pc->data[i].addr);
  }
  printf("\t\t--------------------------------------------------------------------------\n");
  printf("\t\t--------------------------------------------------------------------------\n");
}

5.删除联系人信息功能实现

//删除联系人信息
int FindContactByName(const struct 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(struct Contact* pc)
{
  if (pc->sz == 0)
  {
    printf("联系人为空,操作失败\n");
    return;
  }
  char name[NAME_MAX] = { 0 };
  printf("请输入要删除的联系人姓名:>");
  scanf("%s", name);
  int pos = FindContactByName(pc, name);
  if (pos == -1)
  {
    printf("查找的联系人不存在!!!\n");
  }
  else
  {
    for (int i = pos; i < pc->sz - 1; i++)
    {
      pc->data[i] = pc->data[i + 1];
    }
    pc->sz--;
    printf("删除成功\n");
  }
}

6.查找联系人信息功能实现

//查找联系人信息
void SearchContact(struct Contact* pc)
{
  if (pc->sz == 0)
  {
    printf("通讯录为空,查找失败!!!\n");
    return;
  }
  char name[NAME_MAX] = { 0 };
  printf("请输入要查找的联系人的名字:>");
  scanf("%s", name);
  int pos = FindContactByName(pc, name);
  if (pos == -1)
  {
    printf("联系人不存在!!!\n");
    return;
  }
  else
  {
    printf("\t%15s\t%15s\t%15s\t%15s\t%15s\n\n",
      "姓名", "年龄", "性别", "电话", "住址");
      printf("\t%15s\t%15d\t%15s\t%15s\t%15s\n",
        pc->data[pos].name,
        pc->data[pos].age,
        pc->data[pos].sex,
        pc->data[pos].tele,
        pc->data[pos].addr);
  }
}

7.修改联系人信息功能实现

//修改联系人信息
void ModifyContact(struct Contact* pc)
{
  if (pc->sz == 0)
  {
    printf("通讯录为空,查找失败!!!\n");
    return;
  }
  char name[NAME_MAX] = { 0 };
  printf("请输入要修改的联系人姓名:>");
  scanf("%s", name);
  int pos = FindContactByName(pc, name);
  if (pos == -1)
  {
    printf("联系人不存在!!!\n");
    return;
  }
  else
  {
    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("修改成功\n");
}

8.排序联系人信息功能实现

//排序联系人信息
void SortContact(struct Contact* pc)
{
  if (pc->sz == 0)
  {
    printf("通讯录为空,无法排序!!!\n");
    return;
  }
  int i = 0;
  int j = 0;
  struct PeoInfo tmp;
  for (i = 0; i < pc->sz - 1; i++)
  {
    int flag = 1;
    for (j = 0; j < pc->sz - i - 1; j++)
    {
      if (strcmp(pc->data[j].name, pc->data[j + 1].name) < 0)
      {
        tmp = pc->data[j];
        pc->data[j] = pc->data[j + 1];
        pc->data[j + 1] = tmp;
        flag = 0;
      }
    }
    if (flag == 1)
    {
      return;
    }
  }
  printf("排序成功\n");
}

9.加载和保存联系人信息功能实现

//加载有效信息到通讯录中
void LoadContact(struct Contact* pc)
{
  FILE* pf = fopen("contact.txt", "rb");
  if (pf == NULL)
  {
    perror("contact:fopen");
    return;
  }
  struct PeoInfo tmp = { 0 };
  while (fread(&tmp, sizeof(struct PeoInfo), 1, pf))
  {
    CheckContact(pc);
    pc->data[pc->sz] = tmp;
    pc->sz++;
  }
  fclose(pf);
  pf = NULL;
}
//保存信息
void SaveContact(struct Contact* pc)
{
  //1.打开文件
  FILE* pf = fopen("contact.txt", "wb");
  if (pf == NULL)
  {
    perror("SaveContact:fopen");
    return;
  }
  //2.写数据
  int i = 0;
  for (i = 0; i < pc->sz; i++)
  {
    fwrite(&(pc->data[i]), sizeof(struct PeoInfo), 1, pf);
  }
  //3.关闭文件
  fclose(pf);
  pf = NULL;
}

三、源文件展示

1.test.c

#define _CRT_SECURE_NO_WARNINGS 10
#include "contact.h"
void menu()
{
  printf("\t\t\t\t************************************\n");
  printf("\t\t\t\t******    通讯录管理系统    ********\n");
  printf("\t\t\t\t************************************\n");
  printf("\t\t\t\t*      1.添加联系人---ADD          *\n");
  printf("\t\t\t\t*      2.删除联系人---DEL          *\n");
  printf("\t\t\t\t*      3.查找联系人---SEARCH    *\n");
  printf("\t\t\t\t*      4.修改联系人---MODIFY       *\n");
  printf("\t\t\t\t*      5.显示联系人---SHOW         *\n");
  printf("\t\t\t\t*      6.排序联系人---SORT         *\n");
  printf("\t\t\t\t*      0.退出通讯录---EXIT         *\n");
  printf("\t\t\t\t************************************\n");
  printf("\t\t\t\t************************************\n");
}
enum
{
  EXIT,
  ADD,
  DEL,
  SEARCH,
  MODIFY,
  SHOW,
  SORT
};
int main() 
{
  int input = 0;
  struct 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:
      SortContact(&con);//排序联系人信息
      break;
    case EXIT:
      SaveContact(&con);//保存信息
      DistroyContact(&con);//销毁通讯录信息
      printf("退出通讯录\n");
      break;
    default:
      printf("选择错误,请重新选择\n");
      break;
    }
  } while (input);
  return 0;
}

2.contact.c

#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"
//扩充容量
void CheckContact(struct Contact* pc)
{
  if (pc->sz == pc->capacity)
  {
    struct PeoInfo* ptr = (struct PeoInfo*)realloc(pc->data, (pc->capacity + 2) * sizeof(struct PeoInfo));
    if (ptr != NULL)
    {
      pc->data = ptr;
      pc->capacity += 2;
      printf("扩容成功\n");
    }
    else
    {
      printf("扩容失败\n");
      exit(1);
    }
  }
}
//加载有效信息到通讯录中
void LoadContact(struct Contact* pc)
{
  FILE* pf = fopen("contact.txt", "rb");
  if (pf == NULL)
  {
    perror("contact:fopen");
    return;
  }
  struct PeoInfo tmp = { 0 };
  while (fread(&tmp, sizeof(struct PeoInfo), 1, pf))
  {
    CheckContact(pc);
    pc->data[pc->sz] = tmp;
    pc->sz++;
  }
  fclose(pf);
  pf = NULL;
}
//初始化通讯录
void InitContact(struct Contact* pc)
{
  pc->sz = 0;
  pc->data = (struct PeoInfo*)malloc(DEFAULT_SZ * sizeof(struct PeoInfo));
  pc->capacity = DEFAULT_SZ;
  LoadContact(pc);//加载有效信息到通讯录中
}
//添加联系人信息
void AddContact(struct Contact* pc)
{
  CheckContact(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);
  printf("添加成功\n");
  pc->sz++;
}
//销毁通讯录
void DistroyContact(struct Contact* pc)
{
  free(pc->data);
  pc->data = NULL;
  pc->sz = 0;
  pc->capacity = 0;
}
//显示联系人信息
void ShowContact(struct Contact* pc)
{
  if (pc->sz == 0)
  {
    printf("通讯录为空,显示失败!!!\n");
    return;
  }
  int i = 0;
  printf("\t\t--------------------------------------------------------------------------\n");
  printf("\t\t--------------------------------------------------------------------------\n");
  printf("\t%15s\t%15s\t%15s\t%15s\t%15s\n\n",
    "姓名", "年龄", "性别", "电话", "住址");
  for (i = 0; i < pc->sz; i++)
  {
    printf("\t%15s\t%15d\t%15s\t%15s\t%15s\n",
      pc->data[i].name,
      pc->data[i].age,
      pc->data[i].sex,
      pc->data[i].tele,
      pc->data[i].addr);
  }
  printf("\t\t--------------------------------------------------------------------------\n");
  printf("\t\t--------------------------------------------------------------------------\n");
}
//删除联系人信息
int FindContactByName(const struct 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(struct Contact* pc)
{
  if (pc->sz == 0)
  {
    printf("联系人为空,操作失败\n");
    return;
  }
  char name[NAME_MAX] = { 0 };
  printf("请输入要删除的联系人姓名:>");
  scanf("%s", name);
  int pos = FindContactByName(pc, name);
  if (pos == -1)
  {
    printf("查找的联系人不存在!!!\n");
  }
  else
  {
    for (int i = pos; i < pc->sz - 1; i++)
    {
      pc->data[i] = pc->data[i + 1];
    }
    pc->sz--;
    printf("删除成功\n");
  }
}
//查找联系人信息
void SearchContact(struct Contact* pc)
{
  if (pc->sz == 0)
  {
    printf("通讯录为空,查找失败!!!\n");
    return;
  }
  char name[NAME_MAX] = { 0 };
  printf("请输入要查找的联系人的名字:>");
  scanf("%s", name);
  int pos = FindContactByName(pc, name);
  if (pos == -1)
  {
    printf("联系人不存在!!!\n");
    return;
  }
  else
  {
    printf("\t%15s\t%15s\t%15s\t%15s\t%15s\n\n",
      "姓名", "年龄", "性别", "电话", "住址");
      printf("\t%15s\t%15d\t%15s\t%15s\t%15s\n",
        pc->data[pos].name,
        pc->data[pos].age,
        pc->data[pos].sex,
        pc->data[pos].tele,
        pc->data[pos].addr);
  }
}
//修改联系人信息
void ModifyContact(struct Contact* pc)
{
  if (pc->sz == 0)
  {
    printf("通讯录为空,查找失败!!!\n");
    return;
  }
  char name[NAME_MAX] = { 0 };
  printf("请输入要修改的联系人姓名:>");
  scanf("%s", name);
  int pos = FindContactByName(pc, name);
  if (pos == -1)
  {
    printf("联系人不存在!!!\n");
    return;
  }
  else
  {
    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("修改成功\n");
}
//排序联系人信息
void SortContact(struct Contact* pc)
{
  if (pc->sz == 0)
  {
    printf("通讯录为空,无法排序!!!\n");
    return;
  }
  int i = 0;
  int j = 0;
  struct PeoInfo tmp;
  for (i = 0; i < pc->sz - 1; i++)
  {
    int flag = 1;
    for (j = 0; j < pc->sz - i - 1; j++)
    {
      if (strcmp(pc->data[j].name, pc->data[j + 1].name) < 0)
      {
        tmp = pc->data[j];
        pc->data[j] = pc->data[j + 1];
        pc->data[j + 1] = tmp;
        flag = 0;
      }
    }
    if (flag == 1)
    {
      return;
    }
  }
  printf("排序成功\n");
}
//保存信息
void SaveContact(struct Contact* pc)
{
  //1.打开文件
  FILE* pf = fopen("contact.txt", "wb");
  if (pf == NULL)
  {
    perror("SaveContact:fopen");
    return;
  }
  //2.写数据
  int i = 0;
  for (i = 0; i < pc->sz; i++)
  {
    fwrite(&(pc->data[i]), sizeof(struct PeoInfo), 1, pf);
  }
  //3.关闭文件
  fclose(pf);
  pf = NULL;
}

3.contact.h

#pragma once
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define NAME_MAX 20
#define SEX_MAX 20
#define TELE_MAX 20
#define ADDR_MAX 20
#define DEFAULT_SZ 3
struct PeoInfo
{
  char name[NAME_MAX];//姓名
  int age;      //年龄
  char sex[SEX_MAX];  //性别
  char tele[TELE_MAX];//电话
  char addr[ADDR_MAX];//住址
};
struct Contact
{
  struct PeoInfo* data;//能够动态存储联系人的信息
  int sz;        //记录当前联系人的个数
  int capacity;    //记录当前通讯录的容量
};
//初始化通讯录
void InitContact(struct Contact* pc);
//添加联系人信息
void AddContact(struct Contact* pc);
//销毁通讯录信息
void DistroyContact(struct Contact* pc);
//显示联系人信息
void ShowContact(struct Contact* pc);
//删除联系人信息
void DelContact(struct Contact* pc);
//查找联系人信息
void SearchContact(struct Contact* pc);
//修改联系人信息
void ModifyContact(struct Contact* pc);
//排序联系人信息
void SortContact(struct Contact* pc);
//加载有效信息到通讯录中
void LoadContact(struct Contact* pc);
//保存信息
void SaveContact(struct Contact* pc);

四、演示效果

一个联系人都没有

1ecd1b2606ed46e9956a89f231c9802c.png

存入联系人

1ecd1b2606ed46e9956a89f231c9802c.png

删除联系人1 

1ecd1b2606ed46e9956a89f231c9802c.png

查找联系人2

1ecd1b2606ed46e9956a89f231c9802c.png

修改联系人24

1ecd1b2606ed46e9956a89f231c9802c.png

排序联系人 前后对比

1ecd1b2606ed46e9956a89f231c9802c.png

2020062310470442.png

退出通讯录再次打开,看是否保存了记录

1ecd1b2606ed46e9956a89f231c9802c.png

开始运行后直接让程序打印结果,此时看到屏幕上已经保存了我们之前存的数据,以上就是通讯录的全部内容,如有错误请联系博主;


目录
相关文章
|
3月前
|
存储 C语言
探索C语言数据结构:利用顺序表完成通讯录的实现
本文介绍了如何使用C语言中的顺序表数据结构实现一个简单的通讯录,包括初始化、添加、删除、查找和保存联系人信息的操作,以及自定义结构体用于存储联系人详细信息。
42 2
|
8月前
|
C语言
C语言——通讯录系统—基于 VS2022
C语言——通讯录系统—基于 VS2022
|
3月前
|
存储 C语言
手把手教你用C语言实现通讯录管理系统
手把手教你用C语言实现通讯录管理系统
|
5月前
|
存储 搜索推荐 算法
【C语言】C语言—通讯录管理系统(源码)【独一无二】
【C语言】C语言—通讯录管理系统(源码)【独一无二】
|
5月前
|
存储 数据可视化 C语言
【C语言】C语言 手机通讯录系统的设计 (源码+数据+论文)【独一无二】
【C语言】C语言 手机通讯录系统的设计 (源码+数据+论文)【独一无二】
|
7月前
|
机器学习/深度学习 搜索推荐 程序员
C语言实现个人通讯录(功能优化)-2
C语言实现个人通讯录(功能优化)
|
7月前
|
存储 C语言 索引
C语言实现个人通讯录(功能优化)-1
C语言实现个人通讯录(功能优化)
C语言实现个人通讯录(功能优化)-1
|
7月前
|
C语言
C语言学习记录——通讯录(静态内存)
C语言学习记录——通讯录(静态内存)
38 2
|
8月前
|
存储 C语言
C语言实现通讯录
C语言实现通讯录
44 2
|
8月前
|
存储 C语言
C语言实验-动态顺序表实现简易通讯录(二)
在这个C语言实验中,你将实现一个简单的通讯录,它使用动态顺序表来存储联系人信息。
61 2