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

C語言實(shí)現(xiàn)通訊錄程序

 更新時(shí)間:2021年10月10日 14:20:13   作者:久留不見i  
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)通訊錄程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

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

設(shè)計(jì)要求:

可以存放1000個(gè)人的信息,每個(gè)人的信息包括姓名、年齡、性別、電話、住址

通訊錄功能包括:

1.增加聯(lián)系人

2.刪除指定聯(lián)系人

3.查找指定聯(lián)系人

4.修改指定聯(lián)系人

5.顯示所有聯(lián)系人

6.退出通訊錄

思路分析:

首先我們需要創(chuàng)建3個(gè)文件,分別是源文件(test.c)、通訊錄文件(contact.c)、通訊錄頭文件(contact.h),其中頭文件用來包含頭文件、聲名信息、結(jié)構(gòu)體、創(chuàng)建全局變量以及宏。

我們一步一步完成這個(gè)程序:

1.在源程序中寫一個(gè)菜單函數(shù)menu()以及聯(lián)合體Option,當(dāng)然這個(gè)時(shí)候還沒有引頭文件,不可以運(yùn)行。菜單函數(shù)menu()中清楚的標(biāo)明每個(gè)數(shù)字對應(yīng)的功能,分別是 1.增加聯(lián)系人  2.刪除指定聯(lián)系人  3.查找指定聯(lián)系人  4.修改指定聯(lián)系人  5.顯示所有聯(lián)系人  0.退出通訊錄。在聯(lián)合體中相應(yīng)的成員對應(yīng)數(shù)字0~5。

void menu()
{
 printf("\n");
 printf("**************************************\n");
 printf("******   1. add      2. del     ******\n");
 printf("******   3. search   4.modify   ******\n");
 printf("******   5. show     0. exit    ******\n");
 printf("**************************************\n");
}
 
enum Option
{
 EXIT,   //0
 ADD,    //1
 DEL,    //2
 SEARCH, //3
 MODIFY, //4
 SHOW    //5
};

2.寫主函數(shù)main(),定義input代表要輸入的數(shù),在do while循環(huán)中首先調(diào)用菜單函數(shù)menu(),然后請你輸入一個(gè)數(shù)字,再用switch語句對應(yīng)相應(yīng)的功能,在之前我們說過聯(lián)合體的成員就代表數(shù)字0~5,所以case ADD == case case 1,以此類推。相應(yīng)的選擇對應(yīng)相應(yīng)功能的函數(shù),如果你選了1,則進(jìn)入case ADD,然后調(diào)用AddContact(),傳參&con,當(dāng)然這個(gè)函數(shù)要在后面進(jìn)行創(chuàng)建。con是什么也在后面解釋。

int main()
{
 int input = 0;
 struct Contact con;//創(chuàng)建一個(gè)通訊錄
 InitContact(&con);//初始化通訊錄
 
 do
 {
  menu();
  printf("請選擇:");
  scanf("%d", &input);
  switch (input)
  {
  case ADD:
   AddContact(&con);
   break;
  case DEL:
   DelContact(&con);
   break;
  case SEARCH:
   SearchContact(&con);
   break;
  case MODIFY:
   ModifyContact(&con);
   break;
  case SHOW:
   ShowContact(&con);
   break;
  case EXIT:
   printf("退出通訊錄\n");
   break;
  default:
   printf("選擇錯誤\n");
   break;
  }
 } while (input);
 return 0;
}

3.創(chuàng)建頭文件contact.h,定義結(jié)構(gòu)體類型struct PeoInfo和struct Contact。前者是一個(gè)人的信息,創(chuàng)建了他的結(jié)構(gòu)體類型變量代表創(chuàng)建了一個(gè)人的信息;后者是一個(gè)通訊錄的數(shù)據(jù),創(chuàng)建一個(gè)struct Contact類型的變量包括一個(gè)存放1000個(gè)數(shù)據(jù)的struct PeoInfo類型數(shù)組data[],再定義一個(gè)sz用來計(jì)算存放人數(shù)。當(dāng)然我們看到數(shù)組中的符號是#define定義的宏,用來替換那些數(shù)字。之前看到的con是創(chuàng)建的一個(gè)struct Contact類型變量,并且將他初始化。

#define NAME_MAX 30
#define SEX_MAX 5
#define TELE_MAX 12
#define ADDR_MAX 30
#define MAX 1000
 
struct PeoInfo
{
 char name[NAME_MAX];  //姓名
 int age;              //年齡
 char sex[SEX_MAX];    //性別
 char tele[TELE_MAX];  //電話
 char addr[ADDR_MAX];  //住址
};
 
struct Contact
{
 struct PeoInfo data[MAX];//1000個(gè)人的數(shù)據(jù)存放在data數(shù)組中
 int sz;//通訊錄中當(dāng)前有效元素個(gè)數(shù)
};

4.引用頭文件,并聲明函數(shù)。至此,contact.h就寫完了,因?yàn)檫@個(gè)頭文件已經(jīng)引用了接下來需要用到的#include <stdio.h>和#include <string.h>,所以直接在test.c中引用#include "contact.h"就可以。

#define NAME_MAX 30
#define SEX_MAX 5
#define TELE_MAX 12
#define ADDR_MAX 30
#define MAX 1000
 
#include <stdio.h>
#include <string.h>
 
struct PeoInfo
{
 char name[NAME_MAX];
 int age;
 char sex[SEX_MAX];
 char tele[TELE_MAX];
 char addr[ADDR_MAX];
};
 
struct Contact
{
 struct PeoInfo data[MAX];//1000個(gè)人的數(shù)據(jù)存放在data數(shù)組中
 int sz;//通訊錄中當(dāng)前有效元素個(gè)數(shù)
};
 
void AddContact(struct Contact* pc);//增加聯(lián)系人
 
void DelContact(struct Contact* pc);//刪除指定聯(lián)系人
 
void SearchContact(struct Contact* pc);//查找指定聯(lián)系人
 
void ModifyContact(struct Contact* pc);//修改指定聯(lián)系人
 
void ShowContact(struct Contact* pc);//顯示所有聯(lián)系人

5.寫contact.c也就是通訊錄的具體實(shí)現(xiàn)。首先引頭文件#include "contact.h",然后寫初始化函數(shù)InitContact()。用一個(gè)結(jié)構(gòu)體指針接受(1000個(gè)容量)。將sz賦值為0,數(shù)組全部成員賦值為0,用到memset函數(shù),頭文件#include <string>我們之前已經(jīng)引過了。

#include "contact.h"
 
void InitContact(struct Contact* pc)
{
 pc->sz = 0;//默認(rèn)沒有信息
 memset(pc->data, 0, sizeof(pc->data));
}

6.接下來寫各個(gè)功能的函數(shù):

AddContact()增加聯(lián)系人,輸入信息至指針指向的數(shù)組的第sz位的相應(yīng)成員。sz初始為0,剛好對應(yīng)數(shù)組第0位。

void AddContact(struct Contact* pc)
{
 if (pc->sz == MAX)
 {
  printf("通訊錄已滿,無法添加信息\n");
 }
 else
 {
  printf("請輸入名字:");
  scanf("%s", pc->data[pc->sz].name);
  printf("請輸入年齡:");
  scanf("%d", &(pc->data[pc->sz].age));
  printf("請輸入性別:");
  scanf("%s", pc->data[pc->sz].sex);
  printf("請輸入電話:");
  scanf("%s", pc->data[pc->sz].tele);
  printf("請輸入住址:");
  scanf("%s", pc->data[pc->sz].addr);
 
  printf("添加成功\n");
  pc->sz++;
 }
}

DelContact()刪除指定聯(lián)系人,如果sz不為0,說明通訊錄中有信息,可以進(jìn)行刪除。輸入名字后需進(jìn)行查找,這里通過寫一個(gè)遍歷查找姓名函數(shù)FindContactByName()進(jìn)行查找,其中使用庫函數(shù)strcmp(字符串比較函數(shù)),如果相等則返回?cái)?shù)組下標(biāo)pos,然后在DelContact()從第pos位開始循環(huán),將后一位的值賦給前一位,代表刪除成功,然后sz--。

int FindContactByName(const struct Contact* pc, const char* name)
{
 int i = 0;
 for (i = 0; i < pc->sz; i++)
 {
  if (strcmp(pc->data[i].name, name) == 0)
  {
   return i;
  }
 }
 return -1;
}
 
void DelContact(struct Contact* pc)
{
 if (pc->sz == 0)
 {
  printf("通訊錄為空,無法刪除\n");
  return;
 }
 char name[NAME_MAX] = { 0 };
 printf("請輸入要刪除人的名字:");
 scanf("%s", name);
 //查找
 int pos = FindContactByName(pc, name);
 if (pos == -1)
 {
  printf("指定的聯(lián)系人不存在\n");
 }
 else
 {
  //刪除
  int j = 0;
  for (j = pos; j < pc->sz-1; j++)
  {
   pc->data[j] = pc->data[j + 1];
  }
  pc->sz--;
  printf("刪除成功\n");
 }
}

SearchContact()查找指定聯(lián)系人,直接調(diào)用FindContactByName(),找到后打印信息。

void SearchContact(const struct Contact* pc)
{
 char name[NAME_MAX] = { 0 };
 printf("請輸入要查找人名字:");
 scanf("%s", name);
 int pos = FindContactByName(pc, name);
 if (pos == -1)
 {
  printf("查無此人\n");
 }
 else
 {
  printf("%15s\t%5s\t%8s\t%15s\t%30s\n", "name", "age", "sex", "tele", "addr");
  printf("%15s\t%5d\t%8s\t%15s\t%30s\n",
   pc->data[pos].name,
   pc->data[pos].age,
   pc->data[pos].sex,
   pc->data[pos].tele,
   pc->data[pos].addr);
 }
}

ModifyContac()修改指定聯(lián)系人,使用FindContactByName()查找,如果存在的話返回?cái)?shù)組下標(biāo)pos,然后輸入新的信息覆蓋到指針指向下標(biāo)為pos的數(shù)組data的相應(yīng)成員。

void ModifyContact(struct Contact* pc)
{
 char name[NAME_MAX] = { 0 };
 printf("請輸入要修改人的名字:");
 scanf("%s", name);
 int pos = FindContactByName(pc, name);
 if (pos == -1)
 {
  printf("要修改的人不存在\n");
 }
 else
 {
  printf("請輸入新的名字:");
  scanf("%s", pc->data[pos].name);
  printf("請輸入新的年齡:");
  scanf("%d", &(pc->data[pos].age));
  printf("請輸入新的性別:");
  scanf("%s", pc->data[pos].sex);
  printf("請輸入新的電話:");
  scanf("%s", pc->data[pos].tele);
  printf("請輸入新的住址:");
  scanf("%s", pc->data[pos].addr);
        printf("修改成功");
 }
}

ShowContact()顯示所有聯(lián)系人,進(jìn)入函數(shù)先打印一行表頭,用“\t”分隔開,然后用for循環(huán)打印每一個(gè)人的數(shù)據(jù),直到第sz個(gè)人停下來。

void ShowContact(struct Contact* pc)
{
 int i = 0;
 printf("%15s\t%5s\t%8s\t%15s\t%30s\n","name","age","sex","tele","addr");
 for (i = 0; i < pc->sz; i++)
 {
  printf("%15s\t%5d\t%8s\t%15s\t%30s\n",
   pc->data[i].name,
   pc->data[i].age,
   pc->data[i].sex,
   pc->data[i].tele,
   pc->data[i].addr);
 }
}

寫到這里就已經(jīng)全部完成了通訊錄程序的制作,下面展示所有的代碼:

test.c

#include "contact.h"
 
void menu()
{
 printf("\n");
 printf("**************************************\n");
 printf("******   1. add      2. del     ******\n");
 printf("******   3. search   4.modify   ******\n");
 printf("******   5. show     0. exit    ******\n");
 printf("**************************************\n");
}
 
enum Option
{
 EXIT,
 ADD,
 DEL,
 SEARCH,
 MODIFY,
 SHOW
};
 
int main()
{
 int input = 0;
 struct Contact con;//創(chuàng)建一個(gè)通訊錄
 InitContact(&con);//初始化通訊錄
 
 do
 {
  menu();
  printf("請選擇:");
  scanf("%d", &input);
  switch (input)
  {
  case ADD:
   AddContact(&con);
   break;
  case DEL:
   DelContact(&con);
   break;
  case SEARCH:
   SearchContact(&con);
   break;
  case MODIFY:
   ModifyContact(&con);
   break;
  case SHOW:
   ShowContact(&con);
   break;
  case EXIT:
   printf("退出通訊錄\n");
   break;
  default:
   printf("選擇錯誤\n");
   break;
  }
 } while (input);
 return 0;
}

contact.c

#include "contact.h"
 
void InitContact(struct Contact* pc)
{
 pc->sz = 0;//默認(rèn)沒有信息
 memset(pc->data, 0, sizeof(pc->data));
}
 
void AddContact(struct Contact* pc)
{
 if (pc->sz == MAX)
 {
  printf("通訊錄已滿,無法添加信息\n");
 }
 else
 {
  printf("請輸入名字:");
  scanf("%s", pc->data[pc->sz].name);
  printf("請輸入年齡:");
  scanf("%d", &(pc->data[pc->sz].age));
  printf("請輸入性別:");
  scanf("%s", pc->data[pc->sz].sex);
  printf("請輸入電話:");
  scanf("%s", pc->data[pc->sz].tele);
  printf("請輸入住址:");
  scanf("%s", pc->data[pc->sz].addr);
 
  printf("添加成功\n");
  pc->sz++;
 }
}
 
int FindContactByName(const struct Contact* pc, const char* name)
{
 int i = 0;
 for (i = 0; i < pc->sz; i++)
 {
  if (strcmp(pc->data[i].name, name) == 0)
  {
   return i;
  }
 }
 return -1;
}
 
void DelContact(struct Contact* pc)
{
 if (pc->sz == 0)
 {
  printf("通訊錄為空,無法刪除\n");
  return;
 }
 char name[NAME_MAX] = { 0 };
 printf("請輸入要刪除人的名字:");
 scanf("%s", name);
 //查找
 int pos = FindContactByName(pc, name);
 if (pos == -1)
 {
  printf("指定的聯(lián)系人不存在\n");
 }
 else
 {
  //刪除
  int j = 0;
  for (j = pos; j < pc->sz-1; j++)
  {
   pc->data[j] = pc->data[j + 1];
  }
  pc->sz--;
  printf("刪除成功\n");
 }
}
 
void SearchContact(const struct Contact* pc)
{
 char name[NAME_MAX] = { 0 };
 printf("請輸入要查找人名字:");
 scanf("%s", name);
 int pos = FindContactByName(pc, name);
 if (pos == -1)
 {
  printf("查無此人\n");
 }
 else
 {
  printf("%15s\t%5s\t%8s\t%15s\t%30s\n", "name", "age", "sex", "tele", "addr");
  printf("%15s\t%5d\t%8s\t%15s\t%30s\n",
   pc->data[pos].name,
   pc->data[pos].age,
   pc->data[pos].sex,
   pc->data[pos].tele,
   pc->data[pos].addr);
 }
}
 
void ModifyContact(struct Contact* pc)
{
 char name[NAME_MAX] = { 0 };
 printf("請輸入要修改人的名字:");
 scanf("%s", name);
 int pos = FindContactByName(pc, name);
 if (pos == -1)
 {
  printf("要修改的人不存在\n");
 }
 else
 {
  printf("請輸入新的名字:");
  scanf("%s", pc->data[pos].name);
  printf("請輸入新的年齡:");
  scanf("%d", &(pc->data[pos].age));
  printf("請輸入新的性別:");
  scanf("%s", pc->data[pos].sex);
  printf("請輸入新的電話:");
  scanf("%s", pc->data[pos].tele);
  printf("請輸入新的住址:");
  scanf("%s", pc->data[pos].addr);
  printf("修改成功");
 }
}
 
void ShowContact(struct Contact* pc)
{
 int i = 0;
 printf("%15s\t%5s\t%8s\t%15s\t%30s\n","name","age","sex","tele","addr");
 for (i = 0; i < pc->sz; i++)
 {
  printf("%15s\t%5d\t%8s\t%15s\t%30s\n",
   pc->data[i].name,
   pc->data[i].age,
   pc->data[i].sex,
   pc->data[i].tele,
   pc->data[i].addr);
 }
}

contact.h

#define NAME_MAX 30
#define SEX_MAX 5
#define TELE_MAX 12
#define ADDR_MAX 30
#define MAX 1000
 
#include <stdio.h>
#include <string.h>
 
struct PeoInfo
{
 char name[NAME_MAX];
 int age;
 char sex[SEX_MAX];
 char tele[TELE_MAX];
 char addr[ADDR_MAX];
};
 
struct Contact
{
 struct PeoInfo data[MAX];//1000個(gè)人的數(shù)據(jù)存放在data數(shù)組中
 int sz;//通訊錄中當(dāng)前有效元素個(gè)數(shù)
};
 
void AddContact(struct Contact* pc);//增加聯(lián)系人
 
void DelContact(struct Contact* pc);//刪除指定聯(lián)系人
 
void SearchContact(struct Contact* pc);//查找指定聯(lián)系人
 
void ModifyContact(struct Contact* pc);//修改指定聯(lián)系人
 
void ShowContact(struct Contact* pc);//顯示所有聯(lián)系人

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

相關(guān)文章

  • C++泛型編程基本概念詳解

    C++泛型編程基本概念詳解

    這一篇介紹一下 C++ 編程中與面向?qū)ο蟛⒘械牧硪淮蠓种А盒途幊蹋@一篇主要介紹函數(shù)模板、類模板和成員模板三大部分,需要的朋友可以參考下
    2021-08-08
  • C++教程之變量的作用域與生命周期詳解

    C++教程之變量的作用域與生命周期詳解

    在C++編程中,變量的作用域和生命周期是非常重要的概念。了解這些概念可以幫助開發(fā)人員編寫更好的代碼并避免錯誤。在本文中,我們將探討C++中變量的作用域和生命周期,以及如何正確地使用它們
    2023-04-04
  • C++淺析STL?迭代器?容器的使用

    C++淺析STL?迭代器?容器的使用

    這篇文章主要介紹了C++?STL、迭代器、容器,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-07-07
  • VC++實(shí)現(xiàn)添加文件關(guān)聯(lián)的方法示例

    VC++實(shí)現(xiàn)添加文件關(guān)聯(lián)的方法示例

    這篇文章主要介紹了VC++實(shí)現(xiàn)添加文件關(guān)聯(lián)的方法,涉及VC++針對注冊表的寫入與VC事件響應(yīng)相關(guān)操作技巧,需要的朋友可以參考下
    2017-08-08
  • 使用C++和Crypto++庫實(shí)現(xiàn)AES加密與解密

    使用C++和Crypto++庫實(shí)現(xiàn)AES加密與解密

    在這篇博客中,我們將深入探討如何利用C++和Crypto++庫實(shí)現(xiàn)高效且安全的AES加密與解密機(jī)制,Crypto++是一款高度認(rèn)可的免費(fèi)C++類庫,文中通過代碼示例介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下
    2024-01-01
  • C語言創(chuàng)建鏈表錯誤之通過指針參數(shù)申請動態(tài)內(nèi)存實(shí)例分析

    C語言創(chuàng)建鏈表錯誤之通過指針參數(shù)申請動態(tài)內(nèi)存實(shí)例分析

    這篇文章主要介紹了C語言創(chuàng)建鏈表錯誤之通過指針參數(shù)申請動態(tài)內(nèi)存,是鏈表創(chuàng)建過程中非常常見的經(jīng)典錯誤。實(shí)例中做了較為詳盡的分析,需要的朋友可以參考下
    2014-09-09
  • C/C++在VScode中的配置教程詳解

    C/C++在VScode中的配置教程詳解

    這篇文章主要介紹了C/C++在VScode中的配置教程詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • C++迭代器介紹(iterator、const_iterator、reverse_interator、const_reverse_interator)

    C++迭代器介紹(iterator、const_iterator、reverse_interator、const_rev

    這篇文章主要介紹了C++迭代器介紹(iterator、const_iterator、reverse_interator、const_reverse_interator),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • C語言中的鏈接編寫教程

    C語言中的鏈接編寫教程

    這篇文章主要介紹了C語言中的鏈接編寫教程,是C語言入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-08-08
  • c++ 如何在libuv中實(shí)現(xiàn)tcp服務(wù)器

    c++ 如何在libuv中實(shí)現(xiàn)tcp服務(wù)器

    這篇文章主要介紹了c++ 如何在libuv中實(shí)現(xiàn)tcp服務(wù)器,幫助大家更好的理解和使用libuv,感興趣的朋友可以了解下
    2021-02-02

最新評論