欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言實現(xiàn)簡單電子通訊錄

 更新時間:2020年06月28日 14:55:51   作者:believe_s  
這篇文章主要為大家詳細介紹了C語言實現(xiàn)簡單電子通訊錄,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C語言實現(xiàn)電子通訊錄的具體代碼,供大家參考,具體內(nèi)容如下

制作一個電子通訊錄,通過該通訊錄能錄入好友ID號、姓名(英文)、手
機號碼,家庭住址,公司電話。**
原理:分成5個模塊,將模塊功能實現(xiàn)寫入頭文件中。主函數(shù)部分代碼:
顯示函數(shù)部分,在Markdown里對不齊,意思就這樣,將就一下=。=  

/*******************************************************************
需求:制作一個電子通訊錄,通過該通訊錄能錄入好友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;

 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 < 3; j++)
    {
     sleep (1);   // Linux 使用sleep,參數(shù)為秒
     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 < 3; j++)
    {
     sleep (1);   // Linux 使用sleep,參數(shù)為秒
     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:      //退出通訊錄
   {
    Function = 0;
    system ("clear");
    exit (0);
   }
   default:     //輸入有誤
   {
    Function = 0;
    printf ("\t對不起!您的輸入有誤!請重新輸入:");
    scanf ("%d", &Function);
    break;
   }   
  }  
 } 
 return 0;
}

head.h部分:

#ifndef HEAD_H_
#define HEAD_H_

#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>    // sleep函數(shù)頭文件

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

typedef int ElementType;
typedef struct node
{
 ElementType ID;    // ID號
 char Name [N];    // 姓名
 char Mobile_Phone [N];  // 手機號碼
 char Home_Address [N];  // 家庭住址
 char Company_Tell [N];  // 公司電話
 struct node* next;   // 節(jié)點指針
}Node;
typedef Node* PNode;   //重命名節(jié)點指針類型

//顯示操作界面
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

head.c的代碼:

#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請輸入對應數(shù)字選擇相應功能:");
}

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

 if (NULL == head)
 {
  return ERROR;
 }

 //創(chuàng)建一個新的結點
 PNode p = (PNode) malloc(sizeof(Node)/sizeof(char));
 if (NULL == p)
 {
  return MALLOC_ERROR;
 }

 //將新數(shù)據(jù)賦給新結點
 system("clear"); 
 printf ("\t*************添加好友***************\n");

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

 printf ("\t請輸入好友的名字:");
 scanf ("%s", p->Name);
 printf ("\n");

 printf ("\t請輸入好友的手機號:");
 scanf ("%s", p->Mobile_Phone);
 printf ("\n");

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

 printf ("\t請輸入好友的公司電話:");
 scanf ("%s", p->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->ID,
    p->Name, p->Mobile_Phone, p->Home_Address, 
    p->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->Name, Name)))
   {
    printf ("\t好友信息: \n\tID:%d\n\t姓名: %s\n\t手機號碼: %s\n\t家庭地址:%s\n\t公司電話: %s\n", q->ID, q->Name, q->Mobile_Phone, q->Home_Address, q->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->Name, Name))
  {
   flag = 0;
   printf ("\t好友信息:\n\tID: %d\n\t姓名: %s\n\t手機號碼: %s\n\t家庭地址: %s\n\t公司電話: %s\n", p->ID, p->Name, p->Mobile_Phone, p->Home_Address, p->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->Name, Name))
  {
   p->next = q->next;
   free(q);

   int j;

   printf ("\t正在刪除\n");
   printf ("\t請稍候");
   fflush (stdout);   //強制刷新緩存,輸出顯示
   for (j = 0; j < 3; j++)
   {
    sleep (1);    //linux使用sleep,參數(shù)為秒
    printf (".");
    fflush(stdout);   //強制刷新緩存,輸出顯示
   }
   printf ("\n");
   printf ("\t該好友已成功刪除!\n");
  }
  else if (NULL == q->next && 0 != strcmp(q->Name, Name))
  {
   printf ("\t您的通訊錄沒有該好友!\n");
  }
  p = p->next;
 }
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • C語言中如何利用循環(huán)嵌套輸出一個菱形

    C語言中如何利用循環(huán)嵌套輸出一個菱形

    這篇文章主要介紹了C語言中如何利用循環(huán)嵌套輸出一個菱形問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • C++封裝成DLL并調(diào)用的實現(xiàn)

    C++封裝成DLL并調(diào)用的實現(xiàn)

    本文主要介紹了C++封裝成DLL并調(diào)用的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-03-03
  • C語言數(shù)據(jù)結構之迷宮求解問題

    C語言數(shù)據(jù)結構之迷宮求解問題

    這篇文章主要為大家詳細介紹了C語言數(shù)據(jù)結構之迷宮求解問題,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • Linux UDP服務端和客戶端程序的實現(xiàn)

    Linux UDP服務端和客戶端程序的實現(xiàn)

    這篇文章主要介紹了Linux UDP服務端和客戶端程序的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05
  • C++實現(xiàn)簡易計算器功能

    C++實現(xiàn)簡易計算器功能

    這篇文章主要為大家詳細介紹了C++實現(xiàn)簡易計算器功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • 遞歸形式與非遞歸形式的斐波那契數(shù)列的用法分析

    遞歸形式與非遞歸形式的斐波那契數(shù)列的用法分析

    本篇文章是對遞歸形式與非遞歸形式的斐波那契數(shù)列的用法進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C語言簡易版flappy bird小游戲

    C語言簡易版flappy bird小游戲

    這篇文章主要為大家詳細介紹了C語言簡易版flappy bird小游戲,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • C++深入講解哈夫曼樹

    C++深入講解哈夫曼樹

    給定N個權值作為N個葉子結點,構造一棵二叉樹,若該樹的帶權路徑長度達到最小,稱這樣的二叉樹為最優(yōu)二叉樹,也稱為哈夫曼樹(Huffman Tree)。哈夫曼樹是帶權路徑長度最短的樹,權值較大的結點離根較近
    2022-05-05
  • C語言 深入解讀數(shù)據(jù)結構之堆的實現(xiàn)

    C語言 深入解讀數(shù)據(jù)結構之堆的實現(xiàn)

    堆就是用數(shù)組實現(xiàn)的二叉樹,所以它沒有使用父指針或者子指針。堆根據(jù)“堆屬性”來排序,“堆屬性”決定了樹中節(jié)點的位置
    2021-11-11
  • C語言猜兇手及類似題目的實現(xiàn)示例

    C語言猜兇手及類似題目的實現(xiàn)示例

    本文主要介紹了C語言猜兇手及類似題目的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01

最新評論