溫馨提示×

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

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

C語(yǔ)言如何實(shí)現(xiàn)一個(gè)通訊錄

發(fā)布時(shí)間:2021-05-28 12:23:19 來源:億速云 閱讀:108 作者:小新 欄目:編程語(yǔ)言

這篇文章將為大家詳細(xì)講解有關(guān)C語(yǔ)言如何實(shí)現(xiàn)一個(gè)通訊錄,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

實(shí)現(xiàn)一個(gè)通訊錄,通訊錄可以用來存儲(chǔ)1000個(gè)人的信息,每個(gè)人的信息包括:

姓名、性別、年齡、電話、住址

提供方法:

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

沒有開辟動(dòng)態(tài)內(nèi)存的方法:

頭文件:test.h

#ifndef __CONTACT 
#define __CONTACT 
#define _CRT_SECURE_NO_WARNINGS 1 
#include<stdio.h> 
#include<stdlib.h> 
#include<string.h> 
#include<assert.h> 
#define N 1000 
typedef struct contact 
{ 
 char name[30]; 
 char gender[10]; 
 int age; 
 int telephone; 
 char address[100]; 
};//結(jié)構(gòu)體沒有定義變量屬于聲明一個(gè)結(jié)構(gòu)體類型 
void meau(); 
void show(struct contact *p, int len);//struct contact *p:結(jié)構(gòu)體指針指向這個(gè)結(jié)構(gòu)體, int len:結(jié)構(gòu)體數(shù)組的長(zhǎng)度 
void Add_linkman(struct contact *p, int len,int flag); 
int Delete_linkman(struct contact *p, int d_number, int len);//int d_number選擇要?jiǎng)h除第幾個(gè)結(jié)構(gòu)體的內(nèi)容 
void Find_member(struct contact *p, int d_number, int len);//int d_number表示要查找的第幾個(gè)結(jié)構(gòu)體的內(nèi)容(即聯(lián)系人的信息) 
void empty(struct contact *p); 
void Modify(struct contact *p, int M_member);//int M_member:要修改的第幾個(gè)聯(lián)系人 
int cmp(const void *a, const void *b);//qsort里面的比較函數(shù)定義任意類型 
void sort(struct contact *p, int len);//根據(jù)聯(lián)系人的名字進(jìn)行排序 
#endif//條件編譯

contact.c文件

#include"test.h" 
void meau() 
{ 
 printf("    *******************************************\n"); 
 printf("    *******************************************\n"); 
 printf("    ##############My address book##############\n"); 
 printf("    *1-Add  2-Delete  3-Find  *\n"); 
 printf("    *4-Empty  5-Modify  6-Sort  *\n"); 
 printf("    *0-Exit      7-Show  *\n"); 
 printf("    *******************************************\n"); 
 printf("    *******************************************\n"); 
} 
void show(struct contact *p, int len) 
{ 
 assert(p); 
 int i = 0; 
 for (i = 0; i < len; i++) 
 { 
  printf("name:%s gender:%s age:%d telephone:%d address:%s", \ 
   p[i].name, p[i].gender, p[i].age, p[i].telephone, p[i].address); 
  printf("\n"); 
 } 
} 
void Add_linkman(struct contact *p, int len,int flag) 
{ 
 assert(p); 
 int i = 0; 
 for (i = flag; i < len; i++) 
 { 
  printf("請(qǐng)輸入姓名:"); 
  scanf("%s", &p[i].name); 
  printf("請(qǐng)輸入姓別:"); 
  scanf("%s", &p[i].gender); 
  printf("請(qǐng)輸入年齡:"); 
  scanf("%d", &p[i].age); 
  printf("請(qǐng)輸入電話:"); 
  scanf("%d", &p[i].telephone); 
  printf("請(qǐng)輸入地址:"); 
  scanf("%s", &p[i].address); 
 } 
} 
int Delete_linkman(struct contact *p, int d_number, int len) 
{ 
  
 assert(p); 
 int i = 0; 
 for (i = d_number - 1; i < len - 1; i++) 
 { 
  p[i] = p[i + 1]; 
 
 } 
} 
void Find_member(struct contact *p, int d_number, int len) 
{ 
 assert(p); 
 if (d_number - 1 >= 0 || d_number - 1<len) 
 { 
  printf("name:%s gender:%s age:%d telephone:%d address:%s", \ 
   p[d_number].name, p[d_number].gender, p[d_number].age, p[d_number].telephone, p[d_number].address); 
  printf("\n"); 
 } 
 else 
 { 
  printf("不存在該聯(lián)系人:"); 
  return; 
 } 
 
} 
void empty(struct contact *p) 
{ 
 assert(p); 
 int i = 0; 
 for (i = 0; i <1000; i++) 
 { 
  memset(p+i, 0, sizeof(struct contact)); 
 } 
 
} 
void Modify(struct contact *p, int M_member) 
{ 
 assert(p); 
 printf("修改之前聯(lián)系人的信息為:"); 
 printf("\n"); 
 printf("name:%s gender:%s age:%d telephone:%d address:%s", \ 
  p[M_member - 1].name, p[M_member - 1].gender, p[M_member - 1].age, p[M_member - 1].telephone, p[M_member - 1].address); 
 printf("\n"); 
 printf("請(qǐng)輸入要修改的信息:"); 
 printf("請(qǐng)輸入姓名:"); 
 scanf("%s", &p[M_member - 1].name); 
 printf("請(qǐng)輸入姓別:"); 
 scanf("%s", &p[M_member - 1].gender); 
 printf("請(qǐng)輸入年齡:"); 
 scanf("%d", &p[M_member - 1].age); 
 printf("請(qǐng)輸入電話:"); 
 scanf("%d", &p[M_member - 1].telephone); 
 printf("請(qǐng)輸入地址:"); 
 scanf("%s", &p[M_member - 1].address); 
 
} 
int cmp(const void *a, const void *b) 
{ 
 
 struct contact *aa = (struct contact *)a; 
 struct contact *bb = (struct contact *)b; 
 if (aa->name != bb->name) 
  return(strcmp((aa->name), (bb->name))); 
 
} 
void sort(struct contact *p, int len) 
{ 
 assert(p); 
 qsort(p, len, sizeof(struct contact), cmp); 
 
}

test.c文件:

#include"test.h" 
int main() 
{ 
 int num = 0; 
 struct contact student[N]; 
 int len = 0; 
 int flag = 0;//定義一個(gè)標(biāo)志位來結(jié)構(gòu)體數(shù)組中每個(gè)結(jié)構(gòu)體的位置 
 int total = N; 
 int delete_number = 0; 
 meau(); 
 while (1) 
 { 
  printf("請(qǐng)輸入數(shù)字進(jìn)行選擇:"); 
  scanf("%d", &num); 
   switch (num) 
   { 
   case 1:{ 
      printf("請(qǐng)?zhí)砑觢en個(gè)學(xué)生的信息:"); 
      scanf("%d", &len); 
      Add_linkman(student,len+flag,flag); 
      flag=flag+len; 
      
       
   }break; 
 
   case 2:{ 
      printf("請(qǐng)輸入要?jiǎng)h除的第i個(gè)學(xué)生的信息:"); 
      scanf("%d", &delete_number); 
      Delete_linkman(student, delete_number, len+flag); 
      flag = flag - 1; 
   }break; 
 
   case 3:{ 
      int Find_number = 0; 
      printf("請(qǐng)輸入要查找的第i個(gè)學(xué)生的信息:"); 
      scanf("%d", &Find_number); 
      Find_member(student, delete_number, len+flag); 
 
   }break; 
 
   case 4:{ 
      printf("清空所有聯(lián)系人:"); 
      empty(student); 
 
   }break; 
 
   case 5:{ 
      printf("請(qǐng)輸入要修改的的第i個(gè)學(xué)生的信息:"); 
      int M_member = 0; 
      scanf("%d", &M_member); 
      Modify(student, M_member); 
 
   }break; 
 
   case 6:{ 
      printf("根據(jù)名字排序所有聯(lián)系人:\n"); 
      sort(student, len+flag); 
 
   }break; 
 
   case 7:{ 
      printf("打印所有聯(lián)系人的信息:\n"); 
      show(student, flag); 
 
   }break; 
   case 0:{ 
      exit(1); 
   } 
 
   default:printf("enter error data!!!"); 
 
  } 
 } 
 system("pause"); 
 return 0; 
 
}

關(guān)于“C語(yǔ)言如何實(shí)現(xiàn)一個(gè)通訊錄”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

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

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

AI