C語言實現(xiàn)通訊錄的詳細代碼
更新時間:2021年12月27日 16:08:28 投稿:jbzj
本文詳細講解了C語言實現(xiàn)通訊錄的方法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
(一)實現(xiàn)思路
1.通訊錄功能
添加好友,刪除好友,查找好友,修改好友信息,對好友進行排序
2.模塊化實現(xiàn)各方面的功能
a. test.c
測試通訊錄功能
b. Contact.c
實現(xiàn)通訊錄功能
c. Contact.h
包含通訊錄實現(xiàn)的頭文件
3.代碼實現(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;//記錄當前已經(jīng)有的元素個數(shù)
//存入一個好友,size加1,表示通訊錄人數(shù)增加一個
};
//聲明函數(shù)
//1.對通訊錄進行初始化
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);
//按名字首字母對通訊錄的好友進行排序
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.對好友進行排序\n");
printf("7.幫助使用通訊錄\n");
printf("8.關(guān)于通訊錄\n");
printf("謝謝使用通訊錄!\n");
}
//關(guān)于通訊錄
void AboutContact()
{
printf("通訊錄一般指在日常生活中用筆記錄,也在手機,電腦,電子字典等電子產(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ù)中均涉及查找到該好友才能進行
//為了避免冗余,我們把查找的這個環(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++)
{
//將要查找的好友姓名與通訊錄中的好友進行比較
if (0 == strcmp(ps->data[i].name, name))
{
//若找到,返回其下標
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ù)進行查找,若找到,返回下標,若沒找到,返回-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);
}
}
}
//按照名字的首字母進行排序
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ù)對我們的好友按照名字首字母進行排序
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語言實現(xiàn)通訊錄的詳細代碼的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++數(shù)據(jù)結(jié)構(gòu)之實現(xiàn)循環(huán)順序隊列
這篇文章主要介紹了 C++數(shù)據(jù)結(jié)構(gòu)之實現(xiàn)循環(huán)順序隊列的相關(guān)資料,需要的朋友可以參考下2017-01-01
關(guān)于C語言 const 和 define 區(qū)別
這篇文章主要介紹了關(guān)于C語言 const 和 define 區(qū)別 的相關(guān)資料,需要的朋友可以參考下面文章內(nèi)容2021-09-09
C語言內(nèi)存的動態(tài)分配比較malloc和realloc的區(qū)別
這篇文章主要介紹了C語言內(nèi)存的動態(tài)分配比較malloc和realloc的區(qū)別,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是本文的詳細內(nèi)容,需要的朋友可以參考下2021-07-07

