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

C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單的通訊錄

 更新時(shí)間:2018年02月12日 10:54:55   作者:blueboy82006  
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單的通訊錄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

用C語(yǔ)言寫了一個(gè)簡(jiǎn)單的通訊錄,說簡(jiǎn)單一是功能簡(jiǎn)單,二是也沒有加讀寫文件操作,只是作為鏈表操作的一個(gè)練習(xí),希望能給這方面的新手一此引導(dǎo)和幫助。

代碼:

/* 轉(zhuǎn)貼請(qǐng)注明出處         */ 
/* 作者:小浦原(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;        //頭結(jié)點(diǎn) 
static int flag=1;     //通訊錄創(chuàng)建標(biāo)記 
int CreateNode(void)     //創(chuàng)建單循環(huán)鏈表 
{ 
 if(flag) 
 { 
  LNode *p; 
  h=(LNode *)malloc(sizeof(LNode)); 
  h->next=NULL; 
  p=h; 
  flag--; 
  return 1; 
 } 
 else 
  return 0; 
} 
int InsertNode(void)    //插入函數(shù) 
{ 
 if(!flag) 
 { 
  LNode *t; 
  char name1[12]; 
  char phone1[13]; 
  printf("/n輸入姓名:"); 
  scanf("%s",name1); 
  printf("/n輸入聯(liá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)    //查詢函數(shù) 
{ 
 if(!flag) 
 { 
  LNode *p; 
  int x=0; 
  char name1[12]; 
  printf("/n輸入查詢姓名:"); 
  scanf("%s",name1); 
  p=h; 
  printf("/n查詢結(jié)果:"); 
  while(p->next) 
  { 
   p=p->next; 
   if(strcmp(p->name,name1)==0) 
   { 
    printf("/n姓名:%s/n聯(lián)系電話:%s/n",p->name,p->phone); 
    x++; 
   } 
  } 
  if(!x) 
   printf("/n沒有找到相關(guān)信息!"); 
  return 1; 
 }else 
  return 0; 
} 
int DeletNode(void)    //刪除函數(shù) 
{ 
 if(!flag) 
 { 
  LNode *pre,*p; 
  char name1[12]; 
  p=h; 
  printf("/n輸入要?jiǎng)h除聯(liá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沒有找到要?jiǎng)h除的信息!"); 
  return 1; 
 } 
 else 
  return 0; 
} 
int PrintNode(void)    //輸出函數(shù) 
{ 
 if(!flag) 
 { 
  LNode *p; 
  p=h; 
  while(p->next) 
  { 
   p=p->next; 
   printf("/n姓名:%s /t聯(lián)系電話:%s",p->name,p->phone); 
  } 
  return 1; 
 } 
 else 
  return 0; 
} 
int main()       //主函數(shù) 
{ 
 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] 插入聯(lián)系人的姓名   |/n"); 
 printf("/t/t| [3] 查找聯(lián)系人的姓名   |/n"); 
 printf("/t/t| [4] 刪除聯(lián)系人的姓名   |/n"); 
 printf("/t/t| [5] 輸出所有聯(lián)系人信息   |/n"); 
 printf("/t/t| [0] 退出      |/n"); 
 printf("/t/t|        |/n"); 
 printf("/t/t| 如未建立新表,請(qǐng)先建立!  |/n"); 
 printf("/t/t|        |/n"); 
 printf("/t/t|————————————————|/n"); 
 printf("/n"); 
 printf("請(qǐng)輸入你的選項(xiàng)(0-5):"); 
 while(1) 
 { 
  scanf("%s",&n); 
  while(!(n=='0'||n=='1'||n=='2'||n=='3'||n=='4'||n=='5')) 
  { 
   printf("請(qǐng)輸入你的選項(xiàng)(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("通訊錄已建立,無需重復(fù)建立!/n"); 
   break; 
     } 
  case '2':{ 
   if(InsertNode()) 
    printf("添加成功!/n"); 
   else 
    printf("添加失敗,請(qǐng)先創(chuàng)建通訊錄!/n"); 
   break; 
     } 
  case '3':{ 
   if(SearchNode()) 
    printf("/n"); 
   else 
    printf("查找失敗,請(qǐng)先創(chuàng)建通訊錄!/n"); 
   break; 
     } 
  case '4':{ 
   if(DeletNode()) 
    printf("/n"); 
   else 
    printf("刪除失敗,請(qǐng)先創(chuàng)建通訊錄!/n"); 
   break; 
     } 
  case '5':{ 
   if(PrintNode()) 
    printf("/n以上是全部聯(lián)系人信息./n"); 
   else 
    printf("ERROR,請(qǐng)先創(chuàng)建通訊錄!/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] 插入聯(lián)系人的姓名   |/n"); 
  printf("/t/t| [3] 查找聯(lián)系人的姓名   |/n"); 
  printf("/t/t| [4] 刪除聯(lián)系人的姓名   |/n"); 
  printf("/t/t| [5] 輸出所有聯(lián)系人信息   |/n"); 
  printf("/t/t| [0] 退出      |/n"); 
  printf("/t/t|        |/n"); 
  printf("/t/t| 如未建立新表,請(qǐng)先建立!  |/n"); 
  printf("/t/t|        |/n"); 
  printf("/t/t|————————————————|/n"); 
  printf("/n"); 
 } 
} 

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C語(yǔ)言實(shí)現(xiàn)洗牌與發(fā)牌游戲

    C語(yǔ)言實(shí)現(xiàn)洗牌與發(fā)牌游戲

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言洗牌與發(fā)牌游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • 詳解C++語(yǔ)法中的虛繼承和虛基類

    詳解C++語(yǔ)法中的虛繼承和虛基類

    本文主要介紹了C++語(yǔ)法中的虛繼承和虛基類,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-09-09
  • Qt6.0?qproperty-*不生效原因解決分析

    Qt6.0?qproperty-*不生效原因解決分析

    這篇文章主要為大家介紹了Qt6.0?qproperty-*不生效原因解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • C 語(yǔ)言基礎(chǔ)之C語(yǔ)言的常見關(guān)鍵字

    C 語(yǔ)言基礎(chǔ)之C語(yǔ)言的常見關(guān)鍵字

    C語(yǔ)言中有一些預(yù)先定義的字符串,他們本身被賦予了自身的功能。并且我們?cè)诙x變量的時(shí)候,不能去搶他們的名字來用。他們就是今天的主角:關(guān)鍵字,下面文章將給大家做詳細(xì)介紹
    2021-09-09
  • C++中字符串查找操作的兩則實(shí)例分享

    C++中字符串查找操作的兩則實(shí)例分享

    這篇文章主要介紹了C++中字符串的查找操作的兩則實(shí)例分享,分別是找到第一個(gè)只出現(xiàn)一次的字符以及找出連續(xù)最長(zhǎng)的數(shù)字串的方法,需要的朋友可以參考下
    2016-02-02
  • C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之鏈隊(duì)列的基本操作

    C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之鏈隊(duì)列的基本操作

    這篇文章主要為大家介紹了C語(yǔ)言之鏈隊(duì)列的基本操作,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • 深入淺出理解C語(yǔ)言指針的綜合應(yīng)用

    深入淺出理解C語(yǔ)言指針的綜合應(yīng)用

    指針是指向另一個(gè)變量的變量。意思是一個(gè)指針保存的是另一個(gè)變量的內(nèi)存地址。換句話說,指針保存的并不是普通意義上的數(shù)值,而是另一個(gè)變量的地址值。一個(gè)指針保存了另一個(gè)變量的地址值,就說這個(gè)指針“指向”了那個(gè)變量
    2022-02-02
  • 詳解C++11強(qiáng)類型枚舉

    詳解C++11強(qiáng)類型枚舉

    這篇文章主要介紹了C++11強(qiáng)類型枚舉的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)c++11,感興趣的朋友可以了解下
    2020-08-08
  • C++的try塊與異常處理及調(diào)試技術(shù)實(shí)例解析

    C++的try塊與異常處理及調(diào)試技術(shù)實(shí)例解析

    這篇文章主要介紹了C++的try塊與異常處理及調(diào)試技術(shù)實(shí)例解析,有助于讀者加深對(duì)try塊調(diào)試技術(shù)的認(rèn)識(shí),需要的朋友可以參考下
    2014-07-07
  • C++中的并行與并發(fā)基礎(chǔ)與使用詳解

    C++中的并行與并發(fā)基礎(chǔ)與使用詳解

    對(duì)于多線程來說,這兩個(gè)概念有很大部分是重疊的。對(duì)于很多人來說,它們的意思沒有什么區(qū)別。其區(qū)別主要在于關(guān)注點(diǎn)和意圖方面(差距甚微)。這兩個(gè)詞都是用來對(duì)硬件在同時(shí)執(zhí)行多個(gè)任務(wù)的方式進(jìn)行描述的術(shù)語(yǔ),不過并行更加注重性能
    2023-02-02

最新評(píng)論