溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么在C語言中利用結(jié)構(gòu)體實現(xiàn)一個通訊錄

發(fā)布時間:2021-03-29 16:41:35 來源:億速云 閱讀:152 作者:Leah 欄目:編程語言

怎么在C語言中利用結(jié)構(gòu)體實現(xiàn)一個通訊錄?針對這個問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

提供方法:

1. 添加聯(lián)系人信息
2. 刪除指定聯(lián)系人信息
3. 查找指定聯(lián)系人信息
4. 修改指定聯(lián)系人信息
5. 顯示所有聯(lián)系人信息
6. 清空所有聯(lián)系人

代碼實現(xiàn):

頭文件:

#ifndef __HEAD_H__     ////防止頭文件被多次調(diào)用 
#define __HEAD_H__          
 
#include<stdio.h> 
#include<string.h> 
#include<stdlib.h> 
 
 
#define PEOPLE_MAX 1000 
#define NAME_LENTH 20 
#define SEX_LENTH 5 
#define AGE_LENTH 10 
#define TEL_LENTH 15 
#define ADDR_LENTH 50 //宏定義各個數(shù)據(jù)所需的大小,后續(xù)引用直接可以使用名稱,或需修改時只用修改這里就可以了 
 
struct People 
{ 
  char name[NAME_LENTH]; 
  char sex[SEX_LENTH]; 
  int age; 
  char tel[TEL_LENTH ]; 
  char addr[ADDR_LENTH]; 
};     //定義人的信息結(jié)構(gòu)體(包含各種信息) 
 
struct Contact 
{ 
  struct People person[PEOPLE_MAX]; 
  int user_count; 
};   //定義通訊錄結(jié)構(gòu)體(包含人的信息的結(jié)構(gòu)體和用戶個數(shù)) 
 
typedef struct Contact * pContact; 
 
int add_contact(pContact pcon); //pContact是一個結(jié)構(gòu)體指針類型,pcon是一個指向struct Contact的一個指針 
int dele_contact(pContact pcon); //例如:typedef int * int 即 int *p ==> int p 
int find_contact(pContact pcon); 
int modify_contact(pContact pcon); 
int show_contact(pContact pcon); 
int clear_contact(pContact pcon); 
void menu();    //函數(shù)的聲明 
 
#endif

各種函數(shù)實現(xiàn):

#include"head.h"     
 
 
int add_contact(pContact pcon) 
{ 
  if(pcon->user_count >= PEOPLE_MAX) 
  { 
    printf("contact is full!\n"); 
    return -1; 
  } 
  else 
  { 
    printf("input name,please!\n"); 
    scanf("%s",pcon->person[pcon->user_count].name); 
    printf("input sex,please!\n"); 
    scanf("%s",pcon->person[pcon->user_count].sex); 
    printf("input age,please!\n"); 
    scanf("%d",&pcon->person[pcon->user_count].age); //這里用%d輸出int 
    printf("input tel,please!\n"); 
    scanf("%s",pcon->person[pcon->user_count].tel); 
    printf("input addr,please!\n"); 
    scanf("%s",pcon->person[pcon->user_count].addr); 
    (pcon->user_count)++; 
  } 
  return 0; 
}           //添加信息的實現(xiàn) 
 
 
int dele_contact(pContact pcon) 
{ 
  int ret = find_contact(pcon);  //調(diào)用查找函數(shù)并保存其值 
  if(ret != -1) 
  { 
    int i = 0; 
    i = ret;  //這里要用另一個變量來保存輸入的姓名 
    for(i = 0;i < pcon->user_count-1;i++) 
    { 
      pcon->person[i] = pcon->person[i+1]; //用后一個覆蓋前邊的,如果要刪除的是最后一個不進(jìn)行此步驟 
       
    } 
    pcon->user_count --; //直接減去最后一個即count-- 
  } 
  return 0;   
} 
 
int find_contact(pContact pcon) 
{ 
  int i = 0; 
  char ret[NAME_LENTH]; //用另一個數(shù)組來保存name 
  printf("input name,please!\n"); 
  scanf("%s",ret); 
  while(i <= pcon->user_count) 
  { 
    if(strcmp(ret,pcon->person[i].name)== 0) //比較輸入的姓名和通訊錄中已有的姓名 
    { 
      printf("name\tsex\tage\ttel\taddr\t\n"); 
      printf("%s\t",pcon->person[i].name); 
      printf("%s\t",pcon->person[i].sex); 
      printf("%d\t",pcon->person[i].age); 
      printf("%s\t",pcon->person[i].tel); 
      printf("%s\t\n",pcon->person[i].addr);   
      return i; 
    } 
    i++; 
  } 
  printf("sorry,the name you find is not exist!\n"); 
  return -1; 
} 
 
int modify_contact(pContact pcon)  //修改函數(shù),首先找到如要修改的姓名,然后重新輸入 
{ 
  int ret = find_contact(pcon); 
  if(ret != -1) 
  { 
    printf("input name,please!\n"); 
    scanf("%s",pcon->person[ret].name); 
    printf("input sex,please!\n"); 
    scanf("%s",pcon->person[ret].sex); 
    printf("input age,please!\n"); 
    scanf("%d",&(pcon->person[ret].age)); 
    printf("input tel,please!\n"); 
    scanf("%s",pcon->person[ret].tel); 
    printf("input addr,please!\n"); 
    scanf("%s",pcon->person[ret].addr); 
  } 
  else 
  { 
    printf("sorry,the name you find is not exist!\n"); 
  } 
  return 0; 
} 
 
int show_contact(pContact pcon) 
{ 
  int i = 0; 
  printf("name\tsex\tage\ttel\t\taddr\t\n"); //制表符來制作表頭 
  for(i = 0;i < pcon->user_count;i++) 
  { 
    printf("%s\t",pcon->person[i].name); 
    printf("%s\t",pcon->person[i].sex); 
    printf("%d\t",pcon->person[i].age); 
    printf("%s\t",pcon->person[i].tel); 
    printf("%s\t\n",pcon->person[i].addr); 
  } 
  printf("\n"); 
  return 0; 
} 
 
int clear_contact(pContact pcon) 
{ 
  pcon->user_count = 0 ; 
  return 0; 
}      //清除所有人,直接讓成員個數(shù)變?yōu)?即可 
 
void menu() 
{ 
  printf("-------contact---------\n"); 
  printf(" 1.添加聯(lián)系人信息   \n"); 
  printf(" 2.刪除指定聯(lián)系人信息 \n"); 
  printf(" 3.查找指定聯(lián)系人信息 \n"); 
  printf(" 4.修改指定聯(lián)系人信息 \n"); 
  printf(" 5.顯示所有聯(lián)系人信息 \n"); 
  printf(" 6.清空所有聯(lián)系人   \n"); 
  printf(" 0.謝謝使用      \n"); 
  printf("-------contact---------\n"); 
}

主函數(shù):

#include"head.h" 
 
int main() 
{   
  int n=1; 
  struct Contact people;   //調(diào)用通訊錄結(jié)構(gòu)體 
  people.user_count = 0;   //初始化user_count 
  while(n) 
  { 
    menu(); 
    printf("please input\n"); 
    scanf("%d",&n); 
    switch(n) 
    { 
      case 1: 
      { 
        add_contact(&people); 
        break; 
      } 
      case 2: 
      { 
        dele_contact(&people); 
        break; 
      } 
      case 3: 
      { 
        find_contact(&people); 
        break; 
      }   
      case 4: 
      { 
        modify_contact(&people); 
        break; 
      } 
      case 5: 
      { 
        show_contact(&people); 
        break; 
      } 
      case 6: 
      { 
        clear_contact(&people); 
        break; 
      } 
      default: 
      { 
        return 0; 
        break; 
      } //switch case語句分支選擇不同函數(shù)實現(xiàn)不同作用 
    } 
  } 
  return 0; 
}

結(jié)果實現(xiàn):

怎么在C語言中利用結(jié)構(gòu)體實現(xiàn)一個通訊錄怎么在C語言中利用結(jié)構(gòu)體實現(xiàn)一個通訊錄怎么在C語言中利用結(jié)構(gòu)體實現(xiàn)一個通訊錄怎么在C語言中利用結(jié)構(gòu)體實現(xiàn)一個通訊錄怎么在C語言中利用結(jié)構(gòu)體實現(xiàn)一個通訊錄怎么在C語言中利用結(jié)構(gòu)體實現(xiàn)一個通訊錄怎么在C語言中利用結(jié)構(gòu)體實現(xiàn)一個通訊錄

關(guān)于怎么在C語言中利用結(jié)構(gòu)體實現(xiàn)一個通訊錄問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI