正规的彩票

C语言实现简单电子通讯录(2)

 更新时间: 2020年06月28日 15:01:20   转载 作者: believe_s  
这篇文章主要为大家详细介绍了C语言实现简单电子通讯录的第二部分,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

正规的彩票benwenshiliweidajiafenxianglecyuyanshixianjiandandianzitongxunludejutidaima,gongdajiacankao,jutineirongruxia

zheiliangtianxuewanxitongdiaoyonghebiaozhunio,zhiqiandetongxunlukeyijinxingyixiegaijin,jiangshujubaocundaowenjianzhong(tuzhengguidecaipiaozheilijiubufale)。

yuanli: meiciqidongchengxushixiancongyushewenjianzhongyizhidudexingshiduqubaocundetongxunluxinxi,ranhoujiangduqudaodexinxidaorudaojiegoutizhong;meicizhixingtuichushi,xianjiangyushewenjianyigengxinfangshidakai,bingjiangwenjianzhongzhiqianbaocundexinxiqingkong,ranhoujiangjiegoutideshujubaocundaowenjianzhongqu,zaituichuchengxu。

正规的彩票haiyouzaiwenjianxierushiheduqushi,xianxieru(duqu)baocunshujudezonggeshu,rangchengxuzhidaoyouduoshaoshujuyaoxieru(duqu),ranhoubaocunmeigeshujudezijieshu(chengxuhuigenjumeigeshujudezijieshulaijinxingbaocun),zuihouzaibaocunshuju。

正规的彩票yuzhiqianbanbenxiangbi,gaidongdezhiyouzhuhanshuzhongjiaruleduquwenjianhexierushujuzheilianggebuzhou,haiyoudebiandongjiushijiegouticongyigebianchengleliangge,jiangzhizhencongyuanlaiyigejiegoutizhongfenlichulai,fangbianshujucongwenjianzhongdedaorudaochu。xiamianshidaima(miandenimenwangqianfan,zhengguidecaipiaobazhiqiandedaimadouxiugailekaoguolai):

touwenjian head.h weiyixiugaidejiushijiegouti

#ifndef HEAD_H_
#define HEAD_H_

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>       // sleep函数头文件
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>

#define uint unsigned int
#define OK      0
#define ERROR     -1
#define MALLOC_ERROR -2
#define N       20 


typedef int ElementType;
typedef struct data
{
  ElementType ID;       // ID号
  char Name [N];       // 姓名
  char Mobile_Phone [N];   // 手机号码
  char Home_Address [N];   // 家庭住址
  char Company_Tell [N];   // 公司电话

}Data;
typedef struct _Node
{
  Data data;
  struct _Node* next;     // 节点指针
}Node;

typedef Node* PNode;      // 重命名节点指针类型

//显示操作界面
int Interface_Display ();

//添加好友信息 (尾插法)
int Add_Friend (PNode head, ElementType num);

//显示所有好友信息
int Friend_Information (PNode head);

//查找好友
int Search_Friend (PNode head, char* Name);

//删除好友
void Delete_Friend (PNode head, char* Name);

#endif

yuanwenjian head.c guanyujiegoutidebufenyaojinxingxiugai

#include "head.h"

//显示操作界面
int Interface_Display ()
{
  system ("clear");
  printf ("\t*****************************************\n");
  printf ("\t~     欢迎使用通讯录        ~\n");
  printf ("\t~                    ~\n");
  printf ("\t~   1 >>>>>>>> 添加好友信息     ~\n");
  printf ("\t~   2 >>>>>>>> 列表好友信息     ~\n");
  printf ("\t~   3 >>>>>>>> 搜索好友       ~\n");
  printf ("\t~   4 >>>>>>>> 删除好友       ~\n");
  printf ("\t~   5 >>>>>>>> 退出         ~\n");
  printf ("\t~                    ~\n");
  printf ("\t~                    ~\n");
  printf ("\t~            作者:
believe ~\n");
  printf ("\t*****************************************\n");
  printf ("                      \n");
  printf ("                      \n");
  printf ("\t请输入对应数字选择相应功能:
");
}

//添加好友信息 (尾插法)
int Add_Friend (PNode head, ElementType num)
{
  if (NULL == head)
  {
    return ERROR;
  }

  //创建一个新的结点
  PNode p = (PNode) malloc(sizeof(Node)/sizeof(char));
  if (NULL == p)
  {
    return MALLOC_ERROR;
  }

  //将新数据赋给新结点
  system("clear");  
  printf ("\t*************添加好友***************\n");

  p->data.ID = num;
  printf ("\t好友的ID为:
%d\n", p->data.ID);
  printf ("\n");

  printf ("\t请输入好友的名字:
");
  scanf ("%s", p->data.Name);
  printf ("\n");

  printf ("\t请输入好友的手机号:
");
  scanf ("%s", p->data.Mobile_Phone);
  printf ("\n");

  printf ("\t请输入好友的家庭住址:
");
  scanf ("%s", p->data.Home_Address);
  printf ("\n");

  printf ("\t请输入好友的公司电话:
");
  scanf ("%s", p->data.Company_Tell);
  printf ("\n");

  p->next = NULL;

  //找到最后一个结点
  PNode Ptmp;         //将头结点地址给临时指针Ptmp
  Ptmp = head;
  while (Ptmp->next)
  {
    Ptmp = Ptmp->next;
  }
  Ptmp->next = p;

  return OK;

}

//显示所有好友信息
int Friend_Information (PNode head)
{
  if (NULL == head)
  {
    return ERROR;
  }

  PNode p = head->next;

  printf ("\tID\t姓名\t\t手机号\t\t住址\t\t\t公司电话\n");

  while (p)
  {
    printf ("\t%d\t%s\t\t%s\t\t%s\t\t\t%s\n", p->data.ID, p->data.Name,p->data.Mobile_Phone, p->data.Home_Address, p->data.Company_Tell);
    p = p->next;
  }
  putchar('\n');

  return OK;
}

//通过名字查找好友
int Search_Friend (PNode head, char* Name)     
{
  PNode p = head;
  PNode q = NULL;

  if ((NULL != p) && NULL != (p->next))
  {
    while (p->next) 
    {
      q = p->next;
      if ((NULL != q) && 0 == (strcmp(q->data.Name, Name)))
      {
        printf ("\t好友信息: \n\tID:%d\n\t姓名: %s\n\t手机号码: %s\n\t家庭地址:
%s\n\t公司电话: %s\n", q->data.ID, q->data.Name, q->data.Mobile_Phone, q->data.Home_Address, q->data.Company_Tell);
      }
      else
      {
        printf ("\t对不起,您的通讯录没有该好友!\n");
      }
      p = p->next;
    }
  }

  /* 另一种做法
  if (NULL == head)
  {
    return ERROR;
  }

  PNode p;
  int flag = 1;
  for (p = head->next; p != NULL; p = p->next)
  {
    if (0 == strcmp(p->data.Name, Name))
    {
      flag = 0;
      printf ("\t好友信息:
\n\tID: %d\n\t姓名: %s\n\t手机号码: %s\n\t家庭地址: %s\n\t公司电话: %s\n", p->data.ID, p->data.Name, p->data.Mobile_Phone, p->data.Home_Address, p->data.Company_Tell);
    }
  }
  fi (flag)
  {
    printf ("\t对不起,您的通讯录没有该好友!\n");
  }

  putchar('\n');
  */

  return OK;
}

//删除好友
void Delete_Friend (PNode head, char* Name)
{
  PNode p = head;
  PNode q = NULL;

  while (NULL != p && NULL != (p->next))
  {
    q = p->next;
    if (NULL != q && 0 == strcmp(q->data.Name, Name))
    {
      p->next = q->next;
      free(q);

      int j;

      printf ("\t正在删除\n");
      printf ("\t请稍候");
      fflush (stdout);      //强制刷新缓存,输出显示
      for (j = 0; j < 2; j++)
      {
        sleep (1);       //linux使用sleep,参数为秒
        printf (".");
        fflush(stdout);     //强制刷新缓存,输出显示
      }
      printf ("\n");
      printf ("\t该好友已成功删除!\n");
    }
    else if (NULL == q->next && 0 != strcmp(q->data.Name, Name))
    {
      printf ("\t您的通讯录没有该好友!\n");
    }
    p = p->next;
  }
}

zhuhanshu main.c jiaruleshujudeduquhexieru,yibiaoming

/*******************************************************************
需求:
制作一个电子通讯录,通过该通讯录能录入好友ID号、姓名(英文)、手
机号码,家庭住址,公司电话。
模块:

  主界面:
主要显示软件功能,A)添加好友信息 B)列表好友信息。(包含排序
  功能) C)搜索好友 D)删除好友
  A)用户输入INSERT命令后,让用户输入好友信息。添加成功或失败都需提示
  B)用户输入DISPLAY命令后,好友信息升序排列
  C)用户输入SEARCH命令后,让用户输入将要搜索好友姓名查询。如果未搜索
  到请友好提示。如果搜索到,显示处该好友信息
  D)用户输入DELETE命令后,让用户输入将要删除好友姓名删除,如果存在同
  名的多个好友,则列表出,所有同名的好友信息,让用户通过输入ID号删除
  提示用户删除成功。
**********************************************************************/
#include "head.h"

int main ()
{
  int Function;
  int i = 0;
  char Name[N];
  int cho;

  // 创建头结点并为其分配空间
  PNode head_node = (PNode) malloc(sizeof(Node)/sizeof(char));
  if (NULL == head_node)
  {
    return MALLOC_ERROR;
  }
  head_node->next = NULL;


/****************************************************************
  打开存放信息的文件并将里面的数据导入到链表中区
****************************************************************/
  // 以只读方式打开存放信息的文件,
  FILE *fp1 = fopen ("student.txt", "r+"); 
  if (NULL == fp1) 
  { 
    printf ("fopen"); 
    return -1; 
  } 

  PNode tmp = head_node; 
  int count; 
  int ret; 

  // 保存读记录的个数并判断是否读到文件结尾,如果读到文件结尾,
  // 它返回一个非0 的值
  ret = fread (&count, sizeof(int), 1, fp1); 
  if(ret != 0) 
  { 
    for (i = 0; i < count; i++) 
    {
      // 创建新结点用来保存读取的数据
      Node *node = (Node*)malloc(sizeof(Node)/sizeof(char));   

      int len;          
      fread (&len, sizeof(int), 1, fp1);   // 读取数据长度
      fread (&(node->data), len, 1, fp1);   // 读取数据 

      node->next = NULL;   
      while (tmp->next)            // 向后遍历
      { 
        tmp = tmp->next; 
      } 
      tmp->next = node;            // 将结点导入链表中 
    } 
  } 

  if (ret == 0 && !feof(fp1))           // 读取失败
  { 
    perror ("fread"); 
    return -1; 
  } 
  fclose (fp1);                  // 关闭刚刚打开的文件
/****************************************************************
  文件导入链表结束,关闭文件
****************************************************************/  

  i = 1;               // i初始化(i既是ID编号)
  while (1)
  {
    Interface_Display ();      // 主界面
    scanf ("%d", &Function);

    switch (Function)        // 功能选择
    {
      case 1:           // 添加好友
      {
        Function = 0;
        Add_Friend (head_node, i++);
        int j;

        printf ("\t正在添加\n");
        printf ("\t请稍候");
        fflush (stdout);    // 强制刷新缓存,输出显示
        for (j = 0; j < 2; j++)
        {
          sleep (1);     // Linux 使用sleep,参数为秒
          printf (".");
          fflush (stdout);  // 强制刷新缓存,输出显示
        }
        printf ("\n");
        printf ("\t添加成功!\n");
        printf ("\t返回主菜单请输入1:
");
        scanf ("%d", &cho);
        if (1 == cho)
        {
          break;
        }
        else
        {
          printf ("\t对不起!您的输入有误!请重新输入:
");
          scanf ("%d", &cho);
          break;
        }
        break;
      }      
      case 2:         // 显示好友信息
      {
        system ("clear");
        printf ("\t***********好友信息******************\n");
        printf ("\n");

        Friend_Information (head_node);
        Function = 0;
        printf ("\t返回主菜单请输入1:
");
        scanf ("%d", &cho);
        if (1 == cho)
        {
          break;
        }
        else
        {
          printf ("\t对不起!您的输入有误!请重新输入:
");
          scanf ("%d", &cho);
          break;
        }
        break;
      }
      case 3:         // 查找好友
      {
        system ("clear");
        printf ("\t*************查找好友*************\n");
        printf ("\t请输入您要查找的好友姓名:");
        scanf ("%s", Name);
        printf ("\n");

        int j;     
        printf ("\t正在查找\n");
        printf ("\t请稍候");
        fflush (stdout);    // 强制刷新缓存,输出显示
        for (j = 0; j < 2; j++)
        {
          sleep (1);     // Linux 使用sleep,参数为秒
          printf (".");
          fflush (stdout);  // 强制刷新缓存,输出显示
        }
        printf ("\n");
        Search_Friend (head_node, Name);
        printf ("\t返回主菜单请输入1:
");
        scanf ("%d", &cho);
        if (1 == cho)
        {
          break;
        }
        else
        {
          printf ("\t对不起!您的输入有误!请重新输入:
");
          scanf ("%d", &cho);
          break;
        }
        break;
      }
      case 4:           //删除好友
      {
        system ("clear");
        printf ("\t*************删除好友*************\n");
        printf ("\t请输入要删除好友的姓名:");
        scanf ("%s", Name);
        printf ("\n");
        Delete_Friend (head_node, Name);
        printf ("\t返回主菜单请输入1:
");
        scanf ("%d", &cho);
        if (1 == cho)
        {
          break;
        }
        else
        {
          printf ("\t对不起!您的输入有误!请重新输入:
");
          scanf ("%d", &cho);
          break;
        }
        break;
      }  
      case 5:           //退出通讯录
      {

/****************************************************************
        退出程序前,将链表中的数据导入到文件中去
****************************************************************/
        // 以更新方式打开存放信息的文件(打开时会清空文件)
        FILE *fp2 = fopen ("student.txt", "wb+"); 
        if(NULL == fp2) 
        { 
          printf ("fopen"); 
          return -1; 
        } 

        tmp = head_node->next;     // tmp为第一个结点
        count = 0;           // 用来存放链表长度
        while(tmp)           // 求链表长度
        { 
          count++; 
          tmp = tmp->next; 
        }

        // 要写入数据的个数
        fwrite(&count, sizeof(int), 1, fp2); 
        tmp = head_node;        // tmp初始化
        while (tmp->next) 
        { 
          Node* p = tmp->next; 
          tmp->next = p->next; 

          // 写入数据的长度         
          int len = sizeof(p->data); 
          fwrite (&len, sizeof(int), 1, fp2); 

          //写入数据 
          fwrite (&(p->data), sizeof(Data), 1, fp2); 

          free (p);          
        } 
        fclose (fp2); 
/****************************************************************
        数据保存结束,即将退出程序
****************************************************************/

        Function = 0;
        system ("clear");
        exit (0);
      }
      default:          //输入有误
      {
        Function = 0;
        printf ("\t对不起!您的输入有误!请重新输入:
");
        scanf ("%d", &Function);
        break;
      }      
    }    
  }  

  return 0;
}

yishangjiushibenwendequanbuneirong,xiwangduidajiadexuexiyousuobangzhu,yexiwangdajiaduoduozhichijiaobenzhijia。

正规的彩票相关的文章

  • C/C++中提高查找速度的小技巧

    C/C++中提高查找速度的小技巧

    这篇文章主要给大家介绍了C/C++中提高数组中查找某个元素或者字符串中查找某个字符效率的小技巧,提高速度对正规的彩票日常开发来说还是很有用的,文中给出了详细的示例代码,需要的朋友可以参考借鉴,下面来一起看看吧。
    2016-01-01
  • C++删除指定文件夹下N天及之前日志文件的方法

    C++删除指定文件夹下N天及之前日志文件的方法

    这篇文章主要介绍了C++删除指定文件夹下N天及之前日志文件的方法,涉及C++针对时间判断及文件操作的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2014-09-09
  • C++命名空间namespace的介绍与使用

    C++命名空间namespace的介绍与使用

    今天小编就为大家分享一篇关于C++命名空间namespace的介绍与使用,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2017-12-12
  • break的使用for循环嵌套示例

    break的使用for循环嵌套示例

    这篇文章主要介绍了break的使用for循环嵌套示例,需要的朋友可以参考下
    2013-02-02
  • 详解C++调用Python脚本中的函数的实例代码

    详解C++调用Python脚本中的函数的实例代码

    这篇文章主要介绍了C++调用Python脚本中的函数 ,需要的朋友可以参考下
    2017-11-11
  • 深入讲解C++数据类型转换的相关函数的知识

    深入讲解C++数据类型转换的相关函数的知识

    这篇文章主要介绍了深入讲解C++数据类型转换的相关函数的知识,包括类型转换运算符函数等内容,需要的朋友可以参考下
    2014-09-09
  • C程序中可怕的野指针图文详解

    C程序中可怕的野指针图文详解

    这篇文章主要给大家介绍了关于C程序中可怕的野指针的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用C程序具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2018-07-07
  • 全面了解结构体、联合体和枚举类型

    全面了解结构体、联合体和枚举类型

    下面小编就为大家带来一篇全面了解结构体、联合体和枚举类型。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2015-07-07
  • C语言中堆空间的生成与释放详解

    C语言中堆空间的生成与释放详解

    以下是对C语言中堆空间的生成与释放进行了详细的分析介绍,需要的朋友可以过来参考下
    2012-08-08
  • 深入理解C语言 static、extern与指针函数

    深入理解C语言 static、extern与指针函数

    这篇文章主要介绍了C语言 static、extern与指针函数,有需要的朋友可以参考一下
    2012-12-12

最新评论

正规的彩票_正规彩票平台app下载[首页最快线路√] 彩票官网_彩票官网app|网站首页 彩票平台_彩票平台快三-[平台最快线路√] 彩票app下载_彩票app下载官网下载快三_官方入口 彩票平台_彩票平台app-专注彩票门户 彩票官网_彩票官网app下载网址-HOME 彩票平台_彩票平台登录-老品牌最信誉 彩票app_彩票app客户端下载>> 首页 彩票平台_彩票平台免费送彩金18-点击进入>! 彩票平台_彩票平台官网〖2020购彩首选〗 彩票app_彩票app彩票投注平台-Welcome