用C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易通訊錄
C語(yǔ)言實(shí)現(xiàn)一個(gè)通訊錄,通訊錄可以用來(lái)存儲(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)系人**
思路分析:
首先我們可以分三個(gè)模塊來(lái)解決這個(gè)問(wèn)題,第一個(gè)模塊我們需要一個(gè)頭文件,這個(gè)頭文件里可以包含一些相應(yīng)信息,當(dāng)實(shí)現(xiàn)文件和測(cè)試文件包含自己定義的頭文件時(shí)便可以獲得一些相關(guān)的信息。所以頭文件里應(yīng)該包括一個(gè)結(jié)構(gòu)體,這個(gè)結(jié)構(gòu)體里應(yīng)包含姓名,性別,年齡,電話,住址。同時(shí)還可以定義一個(gè)結(jié)構(gòu)體,這個(gè)結(jié)構(gòu)體里包含通訊錄,同時(shí)通訊錄里人員的計(jì)數(shù)變量,將通訊錄的地址傳到別的地方便可以實(shí)現(xiàn)對(duì)它遍歷或者其他操作。
第二個(gè)模塊便是我們的測(cè)試函數(shù),測(cè)試函數(shù)便可以實(shí)現(xiàn)我們的菜單打印,同時(shí)由我們接收不同的值便可以實(shí)現(xiàn)不同的操作,就是相應(yīng)的方法的實(shí)現(xiàn),這里很明顯可以通過(guò)一個(gè)switch語(yǔ)句來(lái)進(jìn)行控制。
第三個(gè)模塊便是我們的方法實(shí)現(xiàn)的函數(shù),將模塊2里定義的類型為通訊錄的地址傳到各個(gè)方法里,這樣便可以實(shí)現(xiàn)對(duì)通訊錄的操作。
1.linkman.h(頭文件)
#ifndef __LINKMAN_H__
#define __LINKMAN_H__
#include<stdio.h>
#include<windows.h>
#include<string.h>
#pragma warning (disable:4996)
typedef struct LINKMAN//建立結(jié)構(gòu)體,存放聯(lián)系人信息
{
char name[20];
char sex[10];
int age;
int tel[12];
char addr[50];
}LINKMAN;
typedef struct Statis //把通訊錄和人員統(tǒng)計(jì)放在結(jié)構(gòu)體內(nèi)
{
LINKMAN num[1000];
int count;
}Statis;
void inint_linkman(Statis *p);//初始化數(shù)組
void Add_linkman(Statis *p);// 添加聯(lián)系人信息
void Dele_linkman(Statis *p);//刪除指定聯(lián)系人信息
void Find_linkman(Statis *p);//查找指定聯(lián)系人信息
void Revise_linkman(Statis *p);//修改指定聯(lián)系人信息
void Display_linkman(Statis *p);//顯示所有聯(lián)系人信息
void Empty_linkman(Statis *p);//清空所有聯(lián)系人
void sort_linkman(Statis *p);//以名字排序所有聯(lián)系人
#endif
2.test.c(測(cè)試)
#include "linkman.h"
Statis sta;
void menu()//菜單
{
printf("***********************************\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("********7.以名字排序所有聯(lián)系人*****\n");
printf("**************按0退出程序**********\n");
printf("***********************************\n");
}
void test()
{
int i = 0;
do
{
menu();
printf("請(qǐng)輸入你要進(jìn)行的選項(xiàng):");
scanf("%d", &i);
switch (i)
{
case 1:
Add_linkman(&sta);
break;
case 2:
Dele_linkman(&sta);
break;
case 3:
Find_linkman(&sta);
break;
case 4:
Revise_linkman(&sta);
break;
case 5:
Display_linkman(&sta);
break;
case 6:
Empty_linkman(&sta);
break;
case 7:
sort_linkman(&sta);
break;
case 0:
exit(1);
break;
default:
printf("輸入錯(cuò)誤\n");
break;
}
} while (i);
}
int main()
{
inint_linkman(&sta);
test();
system("pause");
return 0;
}
3.game.c(實(shí)現(xiàn))
#include "linkman.h"
void inint_linkman(Statis *p)
{
int count = sizeof(p->num);
p->count = 0;
memset(p->num, 0,count);
}
int Find(Statis *p, char *pname)//對(duì)于一個(gè)聯(lián)系人是否存在封裝一個(gè)函數(shù),在后面的修改、刪除、查找可以用到
{
int i = 0;
for (i = 0; i < (p->count); i++)
{
if (strcmp(p->num[i].name, pname) == 0)
return i;
}
return -1;
}
void menu1()//修改聯(lián)系人時(shí)所用到的菜單
{
printf("*********************\n");
printf("****1.姓名*2.性別****\n");
printf("****3.年齡*4.電話****\n");
printf("****5.地址*6.返回****\n");
printf("*********************\n");
}
void Add_linkman(Statis *p)//添加聯(lián)系人
{
printf("請(qǐng)輸入你要添加的聯(lián)系人姓名:\n");
scanf("%s", p->num[p->count].name);
printf("請(qǐng)輸入你要添加的聯(lián)系人性別:\n");
scanf("%s", p->num[p->count].sex);
printf("請(qǐng)輸入你要添加的聯(lián)系人年齡:\n");
scanf("%d", &(p->num[p->count].age));
printf("請(qǐng)輸入你要添加的聯(lián)系人電話:\n");
scanf("%s", p->num[p->count].tel);
printf("請(qǐng)輸入你要添加的聯(lián)系人地址:\n");
scanf("%s", p->num[p->count].addr);
if ((p->count) > 1000)
{
printf("聯(lián)系人上限\n");
}
else
{
printf("添加成功\n");
p->count++;
}
}
void Dele_linkman(Statis *p)//刪除聯(lián)系人
{
char name[20] = { 0 };
int result = 0;
int n = 0;
int i = 0;
printf("請(qǐng)輸入要?jiǎng)h除人的姓名:\n");
scanf("%s", name);
result = Find(p, name);
if (result != -1)
{
printf("你是否要?jiǎng)h除該聯(lián)系人?\n");
printf("刪除請(qǐng)按1,不刪除請(qǐng)按0\n");
scanf("%d", &n);
if (n == 1)
{
for (i = 0; i < (p->count)-1; i++)
{
p->num[i] = p->num[i + 1];
}
p->count --;
printf("刪除成功\n");
}
else
{
printf("刪除失敗\n");
}
}
else
{
printf("你要?jiǎng)h除的聯(lián)系人不存在\n");
}
}
void Find_linkman(Statis *p)//查找聯(lián)系人
{
char name[20] = { 0 };
int result = 0;
printf("請(qǐng)輸入要查找聯(lián)系人的姓名:\n");
scanf("%s", name);
result = Find(p, name);
if (result != -1)
{
printf("姓名:%s\n", p->num[result].name);
printf("性別:%s\n", p->num[result].sex);
printf("年齡:%d\n", p->num[result].age);
printf("電話:%s\n", p->num[result].tel);
printf("地址:%s\n", p->num[result].addr);
}
else
{
printf("你要查找的聯(lián)系人不存在\n");
}
}
void Revise_linkman(Statis *p)//修改聯(lián)系人
{
char name[20] = {0};
int result = 0;
printf("請(qǐng)輸入你要修改聯(lián)系人的姓名:\n");
scanf("%s", name);
result = Find(p, name);
if (result != -1)
{
printf("姓名:%s\n", p->num[result].name);
printf("性別:%s\n", p->num[result].sex);
printf("年齡:%d\n", p->num[result].age);
printf("電話:%s\n", p->num[result].tel);
printf("地址:%s\n", p->num[result].addr);
int i = 0;
do
{
menu1();
printf("輸入你要修改的選項(xiàng):\n");
scanf("%d", &i);
switch (i)
{
case 1:
printf("請(qǐng)把姓名修改成:");
scanf("%s", p->num[result].name);
break;
case 2:
printf("請(qǐng)把性別修改成:");
scanf("%s", p->num[result].sex);
break;
case 3:
printf("請(qǐng)把年齡修改成:");
scanf("%d", &(p->num[result].age));
break;
case 4:
printf("請(qǐng)把電話修改成:");
scanf("%s", p->num[result].tel);
break;
case 5:
printf("請(qǐng)把地址修改成:");
scanf("%s", p->num[result].addr);
break;
case 0:
break;
default:
printf("輸入錯(cuò)誤");
break;
}
} while (i);
}
else
{
printf("你要修改的聯(lián)系人不存在\n");
}
}
void Display_linkman(Statis *p)//打印所有聯(lián)系人信息
{
int i = 0;
printf("輸出所有人的信息:\n");
printf("%10s%7s%6s%8s%10s\n","名字","性別","年齡","電話","住址");
for (i = 0; i <(p->count); i++)
{
printf("%11s", p->num[i].name);
printf("%5s", p->num[i].sex);
printf("%5d", p->num[i].age);
printf("%10s", p->num[i].tel);
printf("%12s", p->num[i].addr);
printf("\n");
}
}
void Empty_linkman(Statis *p)//清空聯(lián)系人
{
p->count = 0;
}
void sort_linkman(Statis *p)//以名字排序所有聯(lián)系人(冒泡)
{
int i = 0;
int j = 0;
for (i = 0; i < p->count - 1; i++)
for (j = 0; j < p->count - 1 - i; j++)
{
if (strcmp(p->num[j].name, p->num[j + 1].name)>0)
{
LINKMAN tmp;
tmp = p->num[j];
p->num[j] = p->num[j + 1];
p->num[j + 1] = tmp;
}
}
}
程序運(yùn)行結(jié)果部分示范:

到此為止,我們的簡(jiǎn)易通訊錄就實(shí)現(xiàn)啦?。?!
相關(guān)文章
C 語(yǔ)言中實(shí)現(xiàn)環(huán)形緩沖區(qū)
本文主要是介紹 C語(yǔ)言實(shí)現(xiàn)環(huán)形緩沖區(qū),并附有詳細(xì)實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,希望能幫助有需要的小伙伴2016-07-07
c語(yǔ)言實(shí)現(xiàn)學(xué)生管理系統(tǒng)詳解
這篇文章主要為大家介紹了c語(yǔ)言實(shí)現(xiàn)學(xué)生管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助<BR>2021-12-12
C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單掃雷源碼
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單掃雷源碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04
VS Code遠(yuǎn)程連接Linux服務(wù)器調(diào)試C程序的操作方法
這篇文章主要介紹了VS Code遠(yuǎn)程連接Linux服務(wù)器調(diào)試C程序的操作方法,打開遠(yuǎn)程 Linux 服務(wù)器上的文件夾本文以 /root/ 為例,給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-12-12
C++開發(fā)的Redis數(shù)據(jù)導(dǎo)入工具優(yōu)化
這篇文章主要介紹了C++開發(fā)的Redis數(shù)據(jù)導(dǎo)入工具優(yōu)化方法的相關(guān)資料,需要的朋友可以參考下2015-07-07
C語(yǔ)言超詳細(xì)講解雙向帶頭循環(huán)鏈表
帶頭雙向循環(huán)鏈表:結(jié)構(gòu)最復(fù)雜,一般用在單獨(dú)存儲(chǔ)數(shù)據(jù)。實(shí)際中使用的鏈表數(shù)據(jù)結(jié)構(gòu),都是帶頭雙向循環(huán)鏈表。另外這個(gè)結(jié)構(gòu)雖然結(jié)構(gòu)復(fù)雜,但是使用代碼實(shí)現(xiàn)以后會(huì)發(fā)現(xiàn)結(jié)構(gòu)會(huì)帶來(lái)很多優(yōu)勢(shì),實(shí)現(xiàn)反而簡(jiǎn)單2023-02-02

