C语言实现电话簿项目管理

 更新时间:2021年07月29日 10:02:15   作者:往明  
这篇文章主要为大家详细介绍了C语言实现电话簿项目管理,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现电话簿项目管理的具体代码,供大家参考,具体内容如下

1.前言

在C语言的学习,经常有一个需要完成的项目就是电话簿的管理,在刚学习玩C语言基本内容后,面对这么多的项目需求往往无从下手,本文将一步一步完成电话簿的创建。本文提供一种思路,如有更好的实现欢迎讨论。

2.实现功能

本电话簿需要实现的功能有
实现电话簿的初始创建
实现电话簿的后添加
实现电话簿的删除
实现电话簿的查看(按链表的排序)
实现电话簿的查找(名字以及号码)
实现电话簿的排序(名字以及号码)

3.思路解析

3.1二级目录实现电话簿的初始创建

创建电话簿需要知道要保存什么信息,这是用我们的结构体来创建保存信息

typedef struct phone_book
{
 char job[30];//工作信息
 char number[20];//电话号码
 char name[15];//名字拼音
 char email[30];//邮箱信息
 struct phone_book* next;//指向下一个节点
}phone_book;

由于电话簿没有限定有多大,并且是动态变化的,这时候用数组来保存信息显然不合适,这时候就需要链表来实现。
在电话簿第一次运行时,里面没有任何信息,我们需要来创建电话簿。我们需要三个指针来帮助我们解决问题。 其中一个是链表的头指针,两外两个帮助我们开辟新的节点并指向下一个节点让我们的链表接下去。

phone_book* head, * p1, * p2;
head = NULL;//头指针初始化为空
p1 = (phone_book*)malloc(LEN);
p2 = p1;

完成指针的创建我们要输入信息,就是下面这串代码帮我们实现,创建联系人我不想一个一个输入,就用一个循环让它一直跑,直到名字输入0结束。(没有想到其他的好方法来结束欸~)
每输入信息后要往链表里加入,用一个变量记录联系人数量,创建第一个是把它弄到头指针里面去,后面的联系人通过两个指针处理接下去。

while (1)
 {
  printf("请输入姓名(姓名为0时停止创建):"); gets_s(p1->name);
  if (strcmp(p1->name, "0") == 0) break;
  printf("请输入电话号码:"); gets_s(p1->number);
  printf("请输入工作单位:"); gets_s(p1->job);
  printf("请输入E-mail:"); gets_s(p1->email);
  n = n + 1;
  if (n == 1)
   head = p1;
  else
   p2->next = p1;
  p2 = p1;
  p1 = (phone_book*)malloc(LEN);
 }p2->next = NULL;
 return head;

3.2二级目录实现电话簿的后添加

后添加的操作几乎和创建一模一直,只是操作时为了方便把他们加到头指针后面,所以这时候链表的排列并不是按照添加事件的顺序了。(头指针yyds)

3.3二级目录实现电话簿的删除

联系人的删除就有些难以理解了,不过也好理解。找到这个节点后,释放它,在这之前要标记它前一个节点后一个节点,让它俩连接起来。直接上代码。
通过查找我们发现要删除节点p,如果要删除的人正好在第一个,直接把头指针接到后面,如果不是,就让p1和p后面的节点相连,并且释放p

phone_book* p = head, * p1;//p1是p的前一个节点
  if (p == head)
  {
   head = p->next;
   free(p);
  }
  else
  {
   p1->next = p->next;
      free(p);
  }

3.4二级目录实现电话簿的查找

只需要比较信息即可实现,不过分为按名字和号码来实现,这就需要三个小函数来实现看代码即可理解

3.5二级目录实现电话簿的查找

只需要比较信息即可实现,不过分为按名字和号码来实现,这就需要三个小函数来实现看代码即可理解

3.6二级目录实现电话簿的排序

只需要比较信息即可实现,不过分为按名字和号码来实现,这就需要三个小函数来实现看代码即可理解

4.源代码及注释

#define _CRT_SECURE_NO_WARNINGS
#include<string.h> 
#include<stdio.h> 
#include<stdlib.h> 
#include<malloc.h> 
typedef struct phone_book
{
 char job[30];
 char number[20];
 char name[15];
 char email[30];
 struct phone_book* next;
}phone_book;
#define LEN sizeof(phone_book) 
phone_book* creat_list()
{
 phone_book* head, * p1, * p2;
 char name[15];
 int n = 0;
 head = NULL;
 p1 = (phone_book*)malloc(LEN);
 p2 = p1;
 while (1)
 {
  printf("请输入姓名(姓名为0时停止创建):"); gets_s(p1->name);
  if (strcmp(p1->name, "0") == 0) break;
  printf("请输入电话号码:"); gets_s(p1->number);
  printf("请输入工作单位:"); gets_s(p1->job);
  printf("请输入E-mail:"); gets_s(p1->email);
  n = n + 1;
  if (n == 1)
   head = p1;
  else
   p2->next = p1;
  p2 = p1;
  p1 = (phone_book*)malloc(LEN);
 }p2->next = NULL;
 return head;
}//链表创建函数 
void print_list(phone_book* head)
{
 void menu();
 int n = 0;
 printf("现在通讯录中有如下成员:");
 while (head != NULL)
 {
  printf("\n名字:"); puts(head->name);
  printf("\n电话号码:"); puts(head->number);
  printf("\n工作单位:"); puts(head->job);
  printf("\nE-mail:"); puts(head->email);
  putchar('\n');
  head = head->next;
  n++;
  if (n % 8 == 0)
  {
   printf("按回车键显示下一页");
   getchar();
   system("cls");
   menu();
  }
 }
 printf("总共%d个联系人\n", n);
}
int length(phone_book* head)
{
 int n = 0;
 phone_book* p;
 p = head;
 while (p != NULL)
 {
  p = p->next; n++;
 }
 return n;
}//判断联系人个数
void sortbynumber(phone_book* head)
{
 void menu();
 int n = length(head);
 int i, j;
 phone_book temp, * p;
 p = head;
 phone_book a[1000];
 for (i = 1; i <= n; i++)
 {
  strcpy(a[i].name, p->name);
  strcpy(a[i].number, p->number);
  strcpy(a[i].job, p->job);
  strcpy(a[i].email, p->email);
  p = p->next;
 }
 for (i = 1; i <= n - 1; i++)
 {
  for (j = 1; j <= n - i; j++)
  {
   if (strcmp(a[j].number, a[j + 1].number) > 0)

   {
    temp = a[j];
    a[j] = a[j + 1];
    a[j + 1] = temp;
   }
  }
 }
 printf("现在通讯录中有如下成员:");
 for (i = 1; i <= n; i++)
 {
  printf("\n名字:"); puts(a[i].name);
  printf("\n电话号码:"); puts(a[i].number);
  printf("\n工作单位:"); puts(a[i].job);
  printf("\nE-mail:"); puts(a[i].email);
  putchar('\n');
  if (i % 8 == 0)
  {
   printf("按回车键显示下一页");
   getchar();
   system("cls");
   menu();
  }
 }
 printf("总共%d个联系人\n", n);
}
void sortbyname(phone_book* head)
{
 void menu();
 int n = length(head);
 int i, j;
 phone_book temp, * p;
 p = head;
 phone_book a[100];
 for (i = 1; i <= n; i++)
 {
  strcpy(a[i].name, p->name);
  strcpy(a[i].number, p->number);
  strcpy(a[i].job, p->job);
  strcpy(a[i].email, p->email);
  p = p->next;
 }
 for (i = 1; i <= n - 1; i++)
 {
  for (j = 1; j <= n - i; j++)
  {
   if (strcmp(a[j].name, a[j + 1].name) > 0)
   {
    temp = a[j];
    a[j] = a[j + 1];
    a[j + 1] = temp;
   }
  }
 }
 printf("现在通讯录中有如下成员:");
 for (i = 1; i <= n; i++)
 {
  printf("\n名字:"); puts(a[i].name);
  printf("\n电话号码:"); puts(a[i].number);
  printf("\n工作单位:"); puts(a[i].job);
  printf("\nE-mail:"); puts(a[i].email);
  putchar('\n');
  if (i % 8 == 0)
  {
   printf("按回车键显示下一页");
   getchar();
   system("cls");
   menu();
  }
 }
 printf("总共%d个联系人\n", n);
}//排序按照电话号码
void sort_list(phone_book* head)
{
 void menu();
 if (head == NULL)
 {
  printf("电话簿为空,请重新创建!");
  return;
 }
 char a;
 printf("1,按电话号码升序排序\n2,按姓名字母升序排序\n");
 printf("请选择一种排序方法:");
 a = getchar();
 getchar();
 switch (a)
 {
 case'1':sortbynumber(head); break;
 case'2':sortbyname(head); break;
 default:printf("输入有误!\n"); break;
 }
}
void findbyname(phone_book* head)
{
 if (head == NULL)
 {
  printf("电话簿为空,请重新创建"); return;
 }
 char name[15]; printf("请输入名字:");
 gets_s(name);
 while (strcmp(name, head->name) != 0)
 {
  head = head->next;
  if (head == NULL)
  {
   printf("电话簿未有此联系人\n");
   return;
  }
 }
 printf("%s的电话号码为:", name);
 puts(head->number);
 printf("\n工作单位:");
 puts(head->job);
 printf("\nE-mail:");
 puts(head->email);
}
void findbynumber(phone_book* head)
{
 if (head == NULL)
 {
  printf("电话簿为空,请重新创建");
  return;
 }
 char number[20];
 printf("请输入电话号码:");
 gets_s(number);
 while (strcmp(number, head->number) != 0)
 {
  head = head->next;
  if (head == NULL)
  {
   printf("电话簿未有此联系人\n");
   return;
  }
 }
 printf("%s的主人为:", number);
 puts(head->name);
 printf("\n工作单位:");
 puts(head->job);
 printf("\nE-mail:");
 puts(head->email);
}
void find(phone_book* head)
{
 int n;
 printf("    1,通过名字查找\n    2,通过电话号码查找\n    3,退出\n请选择你需要的服务:");
 scanf("%d", &n);
 getchar();
 while (1)
 {
  if (n == 1)
  {
   findbyname(head);
   printf("请选择服务项:");
   scanf("%d", &n);
   getchar();
  }
  if (n == 2)
  {
   findbynumber(head);
   printf("请选择服务项:");
   scanf("%d", &n);
   getchar();
  }
  if (n == 3)
   return;
  else
  {
   printf("输入不正确!");
   printf("请选择服务项:");
   scanf("%d", &n);
   getchar();
  }
 }
}//查找联系人 
void add_list(phone_book* head)
{
 phone_book* p1, * p2, * h;
 h = NULL;
 char name[15];
 p1 = (phone_book*)malloc(LEN);
 p2 = p1;
 int n = 0;
 while (1)
 {
  printf("请输入名字(名字为0时停止)"); gets_s(p1->name);
  if (strcmp(p1->name, "0") == 0)break;
  printf("请输入电话号码:"); gets_s(p1->number);
  printf("请输入工作单位:"); gets_s(p1->job);
  printf("请输入E-mail:"); gets_s(p1->email);
  n = n + 1;
  if (n == 1)
   h = p1;
  else
   p2->next = p1;
  p2 = p1;
  p1 = (phone_book*)malloc(LEN);
 }
 p1 = head->next;
 head->next = h;
 p2->next = p1;
}//添加链表函数 
phone_book* delete_list(phone_book* head)
{
 char a[20];
 printf("请输入联系人名字或电话:");
 gets_s(a);
 if (head == NULL)
 {
  printf("电话簿为空,请重新创建");  return head;
 }
 phone_book* p = head, * p1;
 p1 = NULL;
 while (strcmp(a, p->name) != 0 && strcmp(a, p->number) != 0)
 {
  p1 = p;
  p = p->next;
  if (p == NULL)
  {
   printf("电话簿未有此联系人\n");
   return head;
  }
 }
 printf("查找到了!");
 printf("\n名字:"); puts(p->name);
 printf("\n电话号码:"); puts(p->number);
 printf("\n工作单位:"); puts(p->job);
 printf("\nE-mail:"); puts(p->email);
 putchar('\n'); char b[10]; printf("是否删除该联系人(Y/N)");
 gets_s(b);
 if (strcmp(b, "y") == 0 || strcmp(b, "Y") == 0)
 {
  if (p == head)
  {
   head = p->next;
   free(p);
  }
  else
  {
   p1->next = p->next; free(p);
  }
  printf("成功删除!");
 }
 else if (strcmp(b, "n") == 0 || strcmp(b, "N") == 0)
  printf("取消删除!");
 else
  printf("输入错误!");
 return head;
}//删除链表函数 
void save_list(phone_book* head)
{
 FILE* fp;
 if ((fp = fopen("dianhuabu.dat", "wb")) == NULL)
 {
  printf("File cannot be opened\n");
  exit(0);
 }
 if (head == NULL)
 {
  printf("通讯录为空\n");
  return;
 }
 phone_book* p1 = head;
 while (p1 != NULL)
 {
  if (fwrite(p1, LEN, 1, fp) != 1)
  {
   printf("cannot open file\n");
   return;
  }
  p1 = p1->next;
 }
 printf("保存完毕!\n"); fclose(fp);
}//文件写入函数 
phone_book* load_list(phone_book* head)
{
 FILE* fp;
 if ((fp = fopen("dianhuabu.dat", "rb")) == NULL)
 {
  printf("电话簿为空,请重新创建\n");
  exit(0);
 }phone_book* p1, * p2;
 p1 = (phone_book*)malloc(LEN);
 if (fread(p1, LEN, 1, fp) == 0)
 {
  printf("电话簿为空,请重新创建");
  return head;
 }
 head = p1;
 p2 = p1; p1 = (phone_book*)malloc(LEN);
 while (fread(p1, LEN, 1, fp))
 {
  p2->next = p1;
  p2 = p1;
  p1 = (phone_book*)malloc(LEN);
 }
 p2->next = NULL;
 free(p1);
 return(head);
 fclose(fp);
}//文件读取函数 
void menu()
{
 printf("           欢迎进入电话簿系统            \n");
 printf("********************************************\n");
 printf("        1、创建电话簿(会将原有电话簿覆盖)\n");
 printf("        2、查找联系人               \n");
 printf("        3、添加联系人               \n");
 printf("        4、删除联系人               \n");
 printf("        5、显示联系人               \n");
 printf("        6、查看电话簿(排序)         \n");
 printf("        7、退出系统                 \n");
 printf("********************************************\n");
}//菜单界面 
void main()
{
 system("cls");
 menu();//进入菜单界面  
 printf("          请选择你所需要的服务:");
 int n;
 scanf("%d", &n);
 getchar();
 phone_book* head;
 head = NULL;
 while (1)
 {
  system("cls");
  menu();
  switch (n)
  {
  case 1:
  {
   head = creat_list();
   system("cls");
   menu();
   print_list(head);
   save_list(head);
   printf("********************************************\n");
   printf("\n如需要其他服务,请重新输入:");
   scanf("%d", &n);   getchar(); }break;//创建电话簿(创建链表、写入文件,释放链表) 
  case 2:
  {
   head = load_list(head);
   find(head);
   printf("********************************************\n");
   printf("\n如需要其他服务,请重新输入:");
   scanf("%d", &n);   getchar(); }break;//查找联系人(读入文件、查找函数、释放链表) 
  case 3:
  {
   head = load_list(head);
   add_list(head);
   system("cls");
   menu();
   save_list(head);
   printf("********************************************\n");
   printf("\n如需要其他服务,请重新输入:");
   scanf("%d", &n);   getchar(); }break;//添加联系人(读入文件、添加链表、写入文件、释放链表) 
  case 4:
  {
   head = load_list(head);
   head = delete_list(head);
   save_list(head);
   printf("********************************************\n");
   printf("\n如需要其他服务,请重新输入:");
   scanf("%d", &n);
   getchar(); }break;//删除联系人(读入文件,删除链表、写入文件、释放链表)  
  case 5:
  {
   head = load_list(head);
   print_list(head);
   save_list(head);
  }
  case 6:
  {
   head = load_list(head);
   sort_list(head);
   printf("********************************************\n");
   printf("\n如需要其他服务,请重新输入:");
   scanf("%d", &n);   getchar(); }break;//查看电话簿(读入文件,排序链表、释放链表)   
  case 7:
  {   system("cls");   return; }break;//退出  
  default:
  {
   printf("\n输入有误,请重新输入:");
   scanf("%d", &n);
   getchar();
  }break;
  }
 }
}

5结束语

以上就是电话簿管理完全过程,欢迎探讨。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C语言实现古代时辰计时与现代时间换算

    C语言实现古代时辰计时与现代时间换算

    这篇文章主要为大家详细介绍了如何利用C语言实现古代时辰计时与现代时间换算,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2023-03-03
  • C语言求2的n次方多种方法总结

    C语言求2的n次方多种方法总结

    这篇文章主要给大家介绍了关于C语言求2的n次方多种方法的相关资料,求2的N次幂是一个常用的功能,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-10-10
  • 基于C语言打造高效便捷的通讯录管理系统

    基于C语言打造高效便捷的通讯录管理系统

    这篇文章主要为大家详细介绍了如何基于C语言打造高效便捷的通讯录管理系统,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-02-02
  • 详解C++设计模式编程中策略模式的优缺点及实现

    详解C++设计模式编程中策略模式的优缺点及实现

    这篇文章主要介绍了C++设计模式编程中策略模式的优缺点及实现,文中讨论了策略模式中设计抽象接口的继承和组合之间的区别,需要的朋友可以参考下
    2016-03-03
  • C++写注册表项实例

    C++写注册表项实例

    这篇文章主要介绍了C++写注册表项实例,可实现开机启动的功能,是进行Windows桌面应用程序开发中非常重要的技巧,需要的朋友可以参考下
    2014-10-10
  • Qt 实现钢笔画线效果示例及详细原理

    Qt 实现钢笔画线效果示例及详细原理

    这篇文章主要介绍了Qt 实现钢笔画线效果示例及详细原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • C语言实现打砖块游戏

    C语言实现打砖块游戏

    这篇文章主要为大家详细介绍了C语言实现打砖块游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • C语言员工信息管理系统源代码

    C语言员工信息管理系统源代码

    这篇文章主要为大家详细介绍了C语言员工信息管理系统源代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-12-12
  • C语言中关于动态内存分配的详解

    C语言中关于动态内存分配的详解

    动态内存是指在堆上分配的内存,而静态内存是指在栈上分配的内存。栈上分配的内存是由系统分配和释放的,空间有限,在复合语句或函数运行结束后就会被系统自动释放而堆上分配的内存则不会有这个问题。
    2021-09-09
  • C++实践数组类运算的实现参考

    C++实践数组类运算的实现参考

    今天小编就为大家分享一篇关于C++实践数组类运算的实现参考,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-02-02

最新评论