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

C語言簡易通訊錄的實現(xiàn)代碼

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

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

通訊錄的實現(xiàn):

一.介紹:

運用C語言的數(shù)組、指針、結(jié)構(gòu)體等相關(guān)知識:實現(xiàn)一個簡易的通訊錄:

此通訊錄的大概內(nèi)容為:
通訊錄可存儲1000個人的信息:

每個人的基本信息有:名字+ 年齡+性別 +  電話+ QQ + 地址
此通訊錄所具有的功能:增加+ 刪除 +  查詢 + 修改 +  排序 + 退出

此通訊錄在設(shè)計時:總共設(shè)計了三個文件:

contact.h: 類型的聲明和函數(shù)的聲明

contact.c:函數(shù)功能的具體實現(xiàn)

test.c: 測試文件

二.具體實現(xiàn):

1. contact.h:

此文件中定義該通訊錄中所設(shè)計的功能的函數(shù)聲明以及兩個結(jié)構(gòu)體:

        PeoInfo:存儲通訊錄中每個人的基本信息

       Contact:存儲通訊錄中的數(shù)據(jù)以及通訊錄中的已存儲的人數(shù)

具體代碼實現(xiàn)如下:

//
//類型的聲明+函數(shù)的聲明
//
 
#include <stdio.h>
#include <string.h>
 
#define MAX 1000
 
#define MAX_NAME 20
#define MAX_TELE 12
#define MAX_ADDR 100
#define MAX_QQ 12
#define MAX_SEX 5
 
typedef struct PeoInfo
{
 char name[MAX_NAME];
 char tele[MAX_TELE];
 char addr[MAX_ADDR];
 char qq[MAX_QQ];
 char sex[MAX_SEX];
 short age;
}PeoInfo;
 
//通訊錄
typedef struct Contact
{
 PeoInfo data[MAX];//數(shù)據(jù)
 int sz;//有效個數(shù)
}Contact;
 
 
//添加一個人的信息
void add_contact(Contact* pc);
 
//顯示通訊錄中的信息
void show_contact(Contact* pc);
 
//刪除指定的聯(lián)系人
void del_contact(Contact* pc);
 
//查找指定聯(lián)系人
void search_contact(Contact* pc);
 
//修改指定聯(lián)系人
void modify_contact(Contact* pc);
 
//排序通訊錄的數(shù)據(jù)
void sort_contact(Contact* pc); 

2. contact.c:

此文件是該通訊錄所設(shè)計的功能的具體實現(xiàn):具體包括:

(1) 添加一個人的信息   void add_contact(Contact* pc);

(2)顯示通訊錄中的信息   void show_contact(Contact* pc);

(3)刪除指定的聯(lián)系人  void del_contact(Contact* pc);

(4)查找指定聯(lián)系人  void search_contact(Contact* pc);

(5)修改指定聯(lián)系人  void modify_contact(Contact* pc);

(6)排序通訊錄的數(shù)據(jù)  void sort_contact(Contact* pc);

具體代碼實現(xiàn)如下:

#define _CRT_SECURE_NO_WARNINGS 1
 
#include "contact.h"
 
void add_contact(Contact* pc)
{
 if (pc->sz == MAX)
 {
 printf("通訊錄已滿\n");
 }
 else
 {
 printf("請輸入名字:>");
 scanf("%s", pc->data[pc->sz].name);
 printf("請輸入電話:>");
 scanf("%s", pc->data[pc->sz].tele);
 printf("請輸入地址:>");
 scanf("%s", pc->data[pc->sz].addr);
 printf("請輸入QQ:>");
 scanf("%s", pc->data[pc->sz].qq);
 printf("請輸入性別:>");
 scanf("%s", pc->data[pc->sz].sex);
 printf("請輸入年齡:>");
 scanf("%d", &(pc->data[pc->sz].age));
 
 pc->sz++;
 printf("添加成功\n");
 }
}
 
void show_contact(Contact* pc)
{
 int i = 0;
 printf("%10s %12s %20s %5s %12s %5s\n", "名字", "電話", "地址", "年齡", "QQ", "性別");
 for (i = 0; i < pc->sz; i++)
 {
 printf("%10s %12s %20s %5d %12s %5s\n", pc->data[i].name,
 pc->data[i].tele,
 pc->data[i].addr,
 pc->data[i].age,
 pc->data[i].qq,
 pc->data[i].sex);
 }
}
 
static int find_peo_by_name(Contact* pc, char name[])
{
 int i = 0;
 for (i = 0; i < pc->sz; i++)
 {
 if (strcmp(name, pc->data[i].name) == 0)
 {
 return i;//找到了,返回下標
 }
 }
 return -1;//找不到
}
 
void del_contact(Contact* pc)
{
 
 if (pc->sz == 0)
 {
 printf("抱歉,通訊錄為空\n");
 }
 else
 {
 char name[MAX_NAME] = { 0 };
 printf("請輸入要刪除人的名字:>");
 scanf("%s", name);
 //1. 找到指定的聯(lián)系人的位置
 int pos = find_peo_by_name(pc, name);
 if (pos == -1)
 {
 printf("很遺憾,刪除的人不存在\n");
 }
 else
 {
 //2. 刪除
 int j = 0;
 for (j = pos; j < pc->sz - 1; j++)
 {
 pc->data[j] = pc->data[j + 1];
 }
 pc->sz--;
 printf("刪除成功\n");
 }
 }
}
 
 
void search_contact(Contact* pc)
{
 char name[MAX_NAME] = { 0 };
 printf("請輸入要查找人的名字:>");
 scanf("%s", name);
 int pos = find_peo_by_name(pc, name);
 if (pos == -1)
 {
 printf("查無此人\n");
 }
 else
 {
 printf("%10s %12s %20s %5s %12s %5s\n",
 "名字", "電話", "地址", "年齡", "QQ", "性別");
 printf("%10s %12s %20s %5d %12s %5s\n", pc->data[pos].name,
 pc->data[pos].tele,
 pc->data[pos].addr,
 pc->data[pos].age,
 pc->data[pos].qq,
 pc->data[pos].sex);
 }
}
 
 
void modify_contact(Contact* pc)
{
 char name[MAX_NAME] = { 0 };
 printf("請輸入要修改人的名字:>");
 scanf("%s", name);
 int pos = find_peo_by_name(pc, name);
 if (pos == -1)
 {
 printf("查無此人\n");
 }
 else
 {
 printf("請輸入新的名字:>");
 scanf("%s", pc->data[pos].name);
 printf("請輸入新的電話:>");
 scanf("%s", pc->data[pos].tele);
 printf("請輸入新的地址:>");
 scanf("%s", pc->data[pos].addr);
 printf("請輸入新的QQ:>");
 scanf("%s", pc->data[pos].qq);
 printf("請輸入新的性別:>");
 scanf("%s", pc->data[pos].sex);
 printf("請輸入新的年齡:>");
 scanf("%d", &(pc->data[pos].age));
 }
}
 
void sort_contact(Contact* pc)
{
 int i = 0;
 int j = 0;
 for (i = 0; i < pc->sz - 1; i++)
 {
 int flag = 1;//假設(shè)已經(jīng)有序
 for (j = 0; j < pc->sz - 1 - i; j++)
 {
 if (strcmp(pc->data[j].name, pc->data[j + 1].name) > 0)
 {
 PeoInfo tmp = pc->data[j];
 pc->data[j] = pc->data[j + 1];
 pc->data[j + 1] = tmp;
 flag = 0;
 }
 }
 if (1 == flag)
 {
 break;
 }
 }
}

3.test.c

此文件是對該通訊錄的功能實現(xiàn)的測試文件:包括菜單的打印,根據(jù)用戶的輸入,輸出相關(guān)信息以及該通訊錄功能的完整流程的實現(xiàn)等。

具體代碼實現(xiàn)如下:

#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"
 
//測試文件
//通訊錄1000個人的信息:名字+ 年齡+ 電話 + 地址+ QQ + 性別 
//增 刪 查 改 排序 退出
#define _CRT_SECURE_NO_WARNINGS 1
 
 
void menu()
{
 printf("*******************************\n");
 printf("****** 1. add  2. del * ***\n");
 printf("****** 3. search 4. modify ***\n");
 printf("****** 5. sort 6. show ***\n");
 printf("******  0. exit  ***\n");
 printf("*******************************\n");
}
 
enum Option
{
 EXIT,
 ADD,
 DEL,
 SEARCH,
 MODIFY,
 SORT,
 SHOW
};
 
//first_name
//FirstName
 
void test()
{
 //創(chuàng)建的通訊錄
 Contact con = { 0 };
 int input = 0;
 do
 {
 menu();
 printf("請選擇:>");
 scanf("%d", &input);
 switch (input)
 {
 case ADD:
 add_contact(&con);
 break;
 case DEL:
 del_contact(&con);
 break;
 case SORT:
 sort_contact(&con);
 break;
 case SHOW:
 show_contact(&con);
 break;
 case SEARCH:
 search_contact(&con);
 break;
 case MODIFY:
 modify_contact(&con);
 break;
 case EXIT:
 printf("退出通訊錄\n");
 break;
 default:
 printf("選擇錯誤\n");
 break;
 }
 } while (input);
}
int main()
{
 test();//
 return 0;
}

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

相關(guān)文章

  • C++ 迷宮游戲?qū)崿F(xiàn)代碼

    C++ 迷宮游戲?qū)崿F(xiàn)代碼

    這篇文章主要介紹了C++ 迷宮游戲?qū)崿F(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • C語言實現(xiàn)打飛機游戲

    C語言實現(xiàn)打飛機游戲

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)打飛機游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 使用C/C++訪問MySQL的教程詳解

    使用C/C++訪問MySQL的教程詳解

    在實際開發(fā)中,語言連接MySQL是為了能夠在編程語言中與MySQL數(shù)據(jù)庫進行交互和操作,大部分情況我們都是通過語言連接MySQL,建立與MySQL數(shù)據(jù)庫的連接,本篇文章主要講解使用C/C++訪問MySQL的教程,需要的朋友可以參考下
    2024-08-08
  • C++類和對象到底是什么

    C++類和對象到底是什么

    C++ 是一門面向?qū)ο蟮木幊陶Z言,理解 C++,首先要理解類(Class)和對象(Object)這兩個概念。下面和小編一起來學(xué)習(xí)吧
    2021-09-09
  • 深入理解約瑟夫環(huán)的數(shù)學(xué)優(yōu)化方法

    深入理解約瑟夫環(huán)的數(shù)學(xué)優(yōu)化方法

    本篇文章是對約瑟夫環(huán)的數(shù)學(xué)優(yōu)化方法進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C++標準庫學(xué)習(xí)之weak_ptr智能指針用法詳解

    C++標準庫學(xué)習(xí)之weak_ptr智能指針用法詳解

    這篇文章主要為大家詳細介紹了C++標準庫中weak_ptr智能指針用法的相關(guān)知識,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-12-12
  • C語言 操作符#與##使用方法詳解

    C語言 操作符#與##使用方法詳解

    在類函數(shù)宏中(帶參數(shù)的宏),#號作為一個預(yù)處理運算符,可以把記號轉(zhuǎn)換成字符串。##相當于連接符,它會將兩邊的內(nèi)容連接起來,形成新的標識符,下面請看詳細的教程
    2022-04-04
  • 結(jié)構(gòu)體類型數(shù)據(jù)作為函數(shù)參數(shù)(三種方法)

    結(jié)構(gòu)體類型數(shù)據(jù)作為函數(shù)參數(shù)(三種方法)

    將一個結(jié)構(gòu)體中變量中的數(shù)據(jù)傳遞給另一個函數(shù),有以下三種方法。需要的朋友可以過來參考下,希望對大家有所幫助
    2013-10-10
  • C語言進階教程之字符函數(shù)和字符串函數(shù)

    C語言進階教程之字符函數(shù)和字符串函數(shù)

    C語言中對字符和字符串的處理很是頻繁,但是C語言本身是沒有字符串類型的,字符串通常放在常量字符串中或者字符數(shù)組中,下面這篇文章主要給大家介紹了關(guān)于C語言進階教程之字符函數(shù)和字符串函數(shù)的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • c++支持coroutine的簡單示例

    c++支持coroutine的簡單示例

    這篇文章主要介紹了c++支持coroutine的簡單示例,使用的是linux 平臺做的,需要的朋友可以參考下
    2014-03-03

最新評論