C语言实现简单的通讯录

 更新时间:2018年02月12日 10:54:55   作者:blueboy82006  
这篇文章主要为大家详细介绍了C语言实现简单的通讯录,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

用C语言写了一个简单的通讯录,说简单一是功能简单,二是也没有加读写文件操作,只是作为链表操作的一个练习,希望能给这方面的新手一此引导和帮助。

代码:

/* 转贴请注明出处         */ 
/* 作者:小浦原(ID:blueboy82006)      */ 
/* http://blog.csdn.net/blueboy82006     */ 
#include <stdio.h> 
#include <stdlib.h> 
#include<string.h> 
#include<ctype.h> 
typedef struct node{ 
 char name[12]; 
 char phone[13]; 
 struct node *next; 
}LNode; 
LNode *h;        //头结点 
static int flag=1;     //通讯录创建标记 
int CreateNode(void)     //创建单循环链表 
{ 
 if(flag) 
 { 
  LNode *p; 
  h=(LNode *)malloc(sizeof(LNode)); 
  h->next=NULL; 
  p=h; 
  flag--; 
  return 1; 
 } 
 else 
  return 0; 
} 
int InsertNode(void)    //插入函数 
{ 
 if(!flag) 
 { 
  LNode *t; 
  char name1[12]; 
  char phone1[13]; 
  printf("/n输入姓名:"); 
  scanf("%s",name1); 
  printf("/n输入联系电话:"); 
  scanf("%s",phone1); 
  t=(LNode *)malloc(sizeof(LNode)); 
  strcpy(t->name,name1); 
  strcpy(t->phone,phone1); 
  t->next=h->next; 
  h->next=t; 
  return 1; 
 } 
 else 
  return 0; 
} 
int SearchNode(void)    //查询函数 
{ 
 if(!flag) 
 { 
  LNode *p; 
  int x=0; 
  char name1[12]; 
  printf("/n输入查询姓名:"); 
  scanf("%s",name1); 
  p=h; 
  printf("/n查询结果:"); 
  while(p->next) 
  { 
   p=p->next; 
   if(strcmp(p->name,name1)==0) 
   { 
    printf("/n姓名:%s/n联系电话:%s/n",p->name,p->phone); 
    x++; 
   } 
  } 
  if(!x) 
   printf("/n没有找到相关信息!"); 
  return 1; 
 }else 
  return 0; 
} 
int DeletNode(void)    //删除函数 
{ 
 if(!flag) 
 { 
  LNode *pre,*p; 
  char name1[12]; 
  p=h; 
  printf("/n输入要删除联系人的姓名:"); 
  scanf("%s",name1); 
  while(p->next) 
  { 
   pre=p; 
   p=p->next; 
   if(strcmp(p->name,name1)==0) 
   { 
    pre->next=p->next; 
    free(p); 
    printf("删除成功!/n"); 
    break; 
   } 
  } 
  if(!p->next) 
   printf("/n没有找到要删除的信息!"); 
  return 1; 
 } 
 else 
  return 0; 
} 
int PrintNode(void)    //输出函数 
{ 
 if(!flag) 
 { 
  LNode *p; 
  p=h; 
  while(p->next) 
  { 
   p=p->next; 
   printf("/n姓名:%s /t联系电话:%s",p->name,p->phone); 
  } 
  return 1; 
 } 
 else 
  return 0; 
} 
int main()       //主函数 
{ 
 char n; 
 printf("/n/n"); 
 printf("/t/t   通讯录/t/n"); 
 printf("/t/t|————————————————|/n"); 
 printf("/t/t|        |/n"); 
 printf("/t/t| [1] 建立通讯录     |/n"); 
 printf("/t/t| [2] 插入联系人的姓名   |/n"); 
 printf("/t/t| [3] 查找联系人的姓名   |/n"); 
 printf("/t/t| [4] 删除联系人的姓名   |/n"); 
 printf("/t/t| [5] 输出所有联系人信息   |/n"); 
 printf("/t/t| [0] 退出      |/n"); 
 printf("/t/t|        |/n"); 
 printf("/t/t| 如未建立新表,请先建立!  |/n"); 
 printf("/t/t|        |/n"); 
 printf("/t/t|————————————————|/n"); 
 printf("/n"); 
 printf("请输入你的选项(0-5):"); 
 while(1) 
 { 
  scanf("%s",&n); 
  while(!(n=='0'||n=='1'||n=='2'||n=='3'||n=='4'||n=='5')) 
  { 
   printf("请输入你的选项(0-5):"); 
   scanf("%s",&n); 
  } 
  system("CLS"); 
  switch(n) 
  { 
  case '0':{ 
   printf("/n/t/t感谢您的使用!/n"); 
   return 0; 
     } 
  case '1':{ 
   if(CreateNode()) 
    printf("通讯录建立成功!/n"); 
   else 
    printf("通讯录已建立,无需重复建立!/n"); 
   break; 
     } 
  case '2':{ 
   if(InsertNode()) 
    printf("添加成功!/n"); 
   else 
    printf("添加失败,请先创建通讯录!/n"); 
   break; 
     } 
  case '3':{ 
   if(SearchNode()) 
    printf("/n"); 
   else 
    printf("查找失败,请先创建通讯录!/n"); 
   break; 
     } 
  case '4':{ 
   if(DeletNode()) 
    printf("/n"); 
   else 
    printf("删除失败,请先创建通讯录!/n"); 
   break; 
     } 
  case '5':{ 
   if(PrintNode()) 
    printf("/n以上是全部联系人信息./n"); 
   else 
    printf("ERROR,请先创建通讯录!/n"); 
    
   break; 
     } 
  default:{printf("输入不符合要求!");} 
  } 
  printf("/n/n"); 
  printf("/t/t   通讯录/t/n"); 
  printf("/t/t|————————————————|/n"); 
  printf("/t/t|        |/n"); 
  printf("/t/t| [1] 建立通讯录     |/n"); 
  printf("/t/t| [2] 插入联系人的姓名   |/n"); 
  printf("/t/t| [3] 查找联系人的姓名   |/n"); 
  printf("/t/t| [4] 删除联系人的姓名   |/n"); 
  printf("/t/t| [5] 输出所有联系人信息   |/n"); 
  printf("/t/t| [0] 退出      |/n"); 
  printf("/t/t|        |/n"); 
  printf("/t/t| 如未建立新表,请先建立!  |/n"); 
  printf("/t/t|        |/n"); 
  printf("/t/t|————————————————|/n"); 
  printf("/n"); 
 } 
} 

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

相关文章

  • C++ 内存分配处理函数set_new_handler的使用

    C++ 内存分配处理函数set_new_handler的使用

    这篇文章主要介绍了C++ 内存分配处理函数set_new_handler的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • C++ vector在多线程操作中出现内存错误问题及解决

    C++ vector在多线程操作中出现内存错误问题及解决

    这篇文章主要介绍了C++ vector在多线程操作中出现内存错误问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • C++实现bmp格式图像读写

    C++实现bmp格式图像读写

    这篇文章主要为大家详细介绍了C++实现bmp格式图像读写,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • C语言中关于库函数 qsort 快排的用法

    C语言中关于库函数 qsort 快排的用法

    快速排序Qsort是所有学习算法和数据结构最基础的一个部分,也是考试题和面试的一个小重点。本片文章带你了解Qsort的详细用法规则
    2021-09-09
  • 一文解析C语言中动态内存管理

    一文解析C语言中动态内存管理

    这篇文章主要为大家详细介绍了C语言中动态内存管理的相关知识,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以跟随小编一起学习一下
    2024-02-02
  • C++ OpenCV绘制简易直方图DrawHistImg

    C++ OpenCV绘制简易直方图DrawHistImg

    本文主要介绍了一个能绘制简易直方图的简单函数DrawHistImg,可以帮助大家快速掌握绘制的原理,可以根据自己的创意对其进行改善和补充。需要的朋友可以参考一下
    2021-12-12
  • C语言中对数组赋值的三种形式

    C语言中对数组赋值的三种形式

    这篇文章主要给大家介绍了关于C语言中对数组赋值的3种形式,文中通过示例代码介绍的非常详细,对大家学习或者使用C语言具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • 浅谈带缓冲I/O 和不带缓冲I/O的区别与联系

    浅谈带缓冲I/O 和不带缓冲I/O的区别与联系

    下面小编就为大家带来一篇浅谈带缓冲I/O 和不带缓冲I/O的区别与联系。小编觉得挺不错的现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • C++中rapidjson将map转为json的方法

    C++中rapidjson将map转为json的方法

    今天小编就为大家分享一篇关于C++中rapidjson将map转为json的方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-04-04
  • C++中类模板的应用你了解多少

    C++中类模板的应用你了解多少

    这篇文章主要为大家详细介绍了C++中类模板的应用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02

最新评论