C語言實(shí)現(xiàn)通訊錄的詳細(xì)代碼
(一)實(shí)現(xiàn)思路
1.通訊錄功能
添加好友,刪除好友,查找好友,修改好友信息,對好友進(jìn)行排序
2.模塊化實(shí)現(xiàn)各方面的功能
a. test.c
測試通訊錄功能
b. Contact.c
實(shí)現(xiàn)通訊錄功能
c. Contact.h
包含通訊錄實(shí)現(xiàn)的頭文件
3.代碼實(shí)現(xiàn)
(二)源代碼
A.test.c
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "contact.h"
void menu()
{
printf("*******************************\n");
printf("*** 1.Add 2.Del ***\n");
printf("*** 3.Search 4.Modify ***\n");
printf("*** 5.Show 6.Sort ***\n");
printf("*** 7.Help 8.About0 ***\n");
printf("*** 0.Exit ***\n");
printf("*******************************\n");
}
int main()
{
int input = 0;
//創(chuàng)建通訊錄
int size = 0;
struct Contact con;//一個結(jié)構(gòu)體里包含1000個人的信息和size;
//size表示的是該通訊錄里現(xiàn)在的好友數(shù)
//初始化通訊錄
InitContact(&con);//使size的初始值,以及好友信息初始化為0;
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 Sort:
SortContact(&con);
break;
//退出
case Exit:
printf("退出通訊錄!");
break;
//通訊錄的使用以及幫助
case Help:
HelpContact();
break;
//關(guān)于通訊錄
case About:
AboutContact();
break;
//選擇錯誤
default:
printf("選擇錯誤!");
break;
}
} while (input);
return 0;
}
B.Contact.h
#define _CRT_SECURE_NO_WARNINGS 1
#define Max 1000
#define Max_name 20
#define Max_sex 5
#define Max_tele 12
#define Max_addr 30
enum Option
{
Exit,
Add,
Del,
Search,
Modify,
Show,
Sort,
Help,
About
};
//創(chuàng)建一個結(jié)構(gòu)體來存放通訊錄中要存放的信息
struct PeoInfo
{
char name[Max_name];
int age;
char sex[Max_sex];
char tele[Max_tele];
char addr[Max_addr];
};
//通訊錄類型
struct Contact
{
struct PeoInfo data[Max];//存放一個信息,包括好友姓名,年齡,性別,電話,地址
int size;//記錄當(dāng)前已經(jīng)有的元素個數(shù)
//存入一個好友,size加1,表示通訊錄人數(shù)增加一個
};
//聲明函數(shù)
//1.對通訊錄進(jìn)行初始化
void InitContact(struct Contact* ps);
//增加好友信息
void AddContact(struct Contact* ps);
//刪除好友
void DelContact(struct Contact* ps);
//查找指定姓名的好友
void SearchContact(struct Contact* ps);
//顯示好友信息
void ShowContact(const struct Contact* ps);
//修改好友信息
void ModifyContact( struct Contact* ps);
//按名字首字母對通訊錄的好友進(jìn)行排序
void SortContact( struct Contact* ps);
//幫助使用通訊錄
void HelpContact();
//關(guān)于通訊錄
void AboutContact();
C.Contact.c
#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
//初始化通訊錄
void InitContact(struct Contact* ps)
{
memset(ps->data, 0, sizeof(ps->data));
ps->size = 0;//設(shè)置通訊錄最初只有0個元素
}
//幫助使用通訊錄
void HelpContact()
{
printf("各按鍵的使用:\n");
printf("1.添加好友\n");
printf("2.刪除好友\n");
printf("3.查找好友信息\n");
printf("4.修改好友信息\n");
printf("5.顯示好友信息\n");
printf("6.對好友進(jìn)行排序\n");
printf("7.幫助使用通訊錄\n");
printf("8.關(guān)于通訊錄\n");
printf("謝謝使用通訊錄!\n");
}
//關(guān)于通訊錄
void AboutContact()
{
printf("通訊錄一般指在日常生活中用筆記錄,也在手機(jī),電腦,電子字典等電子產(chǎn)品中擁有這個功能。\n");
}
//增加好友的電話,信息
void AddContact(struct Contact* ps)
{
if (ps->size == Max)
{
printf("通訊錄已滿,無法增加!\n");
}
else
{
printf("請輸入姓名:");
scanf("%s", ps->data[ps->size].name);
//除了年齡,其他都是數(shù)組,直接用數(shù)組名
printf("請輸入年齡:");
scanf("%d", &(ps->data[ps->size].age));
//年齡不是數(shù)組,則需要&
printf("請輸入性別:");
scanf("%s", ps->data[ps->size].sex);
printf("請輸入電話:");
scanf("%s", ps->data[ps->size].tele);
printf("請輸入地址:");
scanf("%s", ps->data[ps->size].addr);
ps->size++;
//添加成功一個1好友,size加1,;
printf("添加成功!\n");
}
}
//在刪除,查找,修改的函數(shù)中均涉及查找到該好友才能進(jìn)行
//為了避免冗余,我們把查找的這個環(huán)節(jié)從函數(shù)中抽離出來
//在函數(shù)中直接使用,就不會顯得重復(fù)
static int Find_by_name(struct Contact* ps, char name[Max_name])
{
int i;
for (i = 0; i < ps->size; i++)
{
//將要查找的好友姓名與通訊錄中的好友進(jìn)行比較
if (0 == strcmp(ps->data[i].name, name))
{
//若找到,返回其下標(biāo)
return i;
}
}
//若都循環(huán),比對完了以后還沒找到就返回-1
return -1;
}
//刪除好友信息
void DelContact(struct Contact* ps)
{
int j;
char name[Max_name];
printf("請輸入刪除好友的名字:");
scanf("%s", name);
//1.查找要刪除的人的位置
int pos = Find_by_name(ps, name);
//調(diào)用函數(shù)進(jìn)行查找,若找到,返回下標(biāo),若沒找到,返回-1;
//2.刪除
if (pos==-1)
{
printf("該好友不存在!\n");
}
else
{
//刪除數(shù)據(jù)
for (j = pos; j < ps->size - 1; j++)
{
ps->data[j] = ps->data[j + 1];
//刪除數(shù)據(jù)后,后面的元素位置都改變,向前移動一個位置;
}
ps->size--;
//刪除一個好友,size-1.
printf("刪除成功!\n");
}
}
//查找指定好友信息
void SearchContact(struct Contact* ps)
{
char name[Max_name];
printf("輸入要查找的好友姓名:");
scanf("%s", name);
int pos = Find_by_name(ps, name);
if (pos ==-1)
{
printf("該好友不存在!\n");
}
else
{
printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年齡", "性別", "電話", "地址");
printf("%10s\t%4d\t%5s\t%12s\t%20s\n",
ps->data[pos].name,
ps->data[pos].age,
ps->data[pos].sex,
ps->data[pos].tele,
ps->data[pos].addr);
}
}
//修改好友信息
void ModifyContact(struct Contact* ps)
{
char name[Max_name];
printf("請輸入需要修改信息的好友姓名:");
scanf("%s", name);
int pos=Find_by_name(ps, name);
if (pos == -1)
{
printf("該用戶不存在!\n");
}
else
{
printf("請輸入姓名:");
scanf("%s", ps->data[pos].name);
printf("請輸入年齡:");
scanf("%d", &(ps->data[pos].age));
printf("請輸入性別:");
scanf("%s", ps->data[pos].sex);
printf("請輸入電話:");
scanf("%s", ps->data[pos].tele);
printf("請輸入地址:");
scanf("%s", ps->data[pos].addr);
printf("修改成功!\n");
}
}
//顯示出好友的基本信息
void ShowContact(const struct Contact* ps)
{
if (ps->size == 0)
{
printf("通訊錄為空!\n");
}
else
{
int i = 0;
printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年齡", "性別", "電話", "地址");
for (i = 0; i < ps->size; i++)
{
printf("%10s\t%4d\t%5s\t%12s\t%20s\n",
ps->data[i].name,
ps->data[i].age,
ps->data[i].sex,
ps->data[i].tele,
ps->data[i].addr);
}
}
}
//按照名字的首字母進(jìn)行排序
int cmp_stu_by_name(const void* e1, const void* e2)
{
return (strcmp(((struct Contact*)e1)->data->name, ((struct Contact*)e2)->data->name));
}
//我們用qsort()函數(shù)對我們的好友按照名字首字母進(jìn)行排序
void SortContact( struct Contact* ps)
{
qsort(ps->data, ps->size, sizeof(ps->data[0]), cmp_stu_by_name);
printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年齡", "性別", "電話", "地址");
int i;
for (i = 0; i < ps->size; i++)
{
printf("%10s\t%4d\t%5s\t%12s\t%20s\n",
ps->data[i].name,
ps->data[i].age,
ps->data[i].sex,
ps->data[i].tele,
ps->data[i].addr);
}
}
到此這篇關(guān)于C語言實(shí)現(xiàn)通訊錄的詳細(xì)代碼的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語言完整實(shí)現(xiàn)12種排序算法(小結(jié))
本文主要介紹了C語言完整實(shí)現(xiàn)12種排序算法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05
C語言實(shí)現(xiàn)飛機(jī)票務(wù)系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)飛機(jī)票務(wù)系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-12-12
C++?OpenCV實(shí)現(xiàn)白平衡之完美反射算法
完美反射算法是白平衡各種算法中較常見的一種,比灰度世界算法更優(yōu)。本文將利用C++和OpenCV實(shí)現(xiàn)白平衡中的完美反射算法,需要的可以參考一下2022-05-05
Matlab實(shí)現(xiàn)繪制有氣泡感的網(wǎng)絡(luò)圖
這篇文章主要介紹了如何利用Matlab實(shí)現(xiàn)繪制有氣泡感的網(wǎng)絡(luò)圖,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Matlab有一定的幫助,需要的可以參考一下2023-02-02
VSstudio中scanf返回值被忽略的原因及解決方法(推薦)
這篇文章主要介紹了VSstudio中scanf返回值被忽略的原因及其解決方法,scanf返回值被忽略,接下來我就告訴大家該如何解決這個問題,需要的朋友可以參考下2022-09-09

