C語言實(shí)現(xiàn)簡單電子通訊錄
本文實(shí)例為大家分享了C語言實(shí)現(xiàn)電子通訊錄的具體代碼,供大家參考,具體內(nèi)容如下
制作一個電子通訊錄,通過該通訊錄能錄入好友ID號、姓名(英文)、手
機(jī)號碼,家庭住址,公司電話。**
原理:分成5個模塊,將模塊功能實(shí)現(xiàn)寫入頭文件中。主函數(shù)部分代碼:
顯示函數(shù)部分,在Markdown里對不齊,意思就這樣,將就一下=。=


/*******************************************************************
需求:制作一個電子通訊錄,通過該通訊錄能錄入好友ID號、姓名(英文)、手
機(jī)號碼,家庭住址,公司電話。
模塊:
主界面:主要顯示軟件功能,A)添加好友信息 B)列表好友信息。(包含排序
功能) C)搜索好友 D)刪除好友
A)用戶輸入INSERT命令后,讓用戶輸入好友信息。添加成功或失敗都需提示
B)用戶輸入DISPLAY命令后,好友信息升序排列
C)用戶輸入SEARCH命令后,讓用戶輸入將要搜索好友姓名查詢。如果未搜索
到請友好提示。如果搜索到,顯示處該好友信息
D)用戶輸入DELETE命令后,讓用戶輸入將要刪除好友姓名刪除,如果存在同
名的多個好友,則列表出,所有同名的好友信息,讓用戶通過輸入ID號刪除
提示用戶刪除成功。
**********************************************************************/
#include "head.h"
int main ()
{
int Function;
int i = 0;
char Name[N];
int cho;
PNode head_node = (PNode) malloc(sizeof(Node)/sizeof(char));
if (NULL == head_node)
{
return MALLOC_ERROR;
}
head_node->next = NULL;
while (1)
{
Interface_Display ();
scanf ("%d", &Function);
switch (Function) // 功能選擇
{
case 1: // 添加好友
{
Function = 0;
Add_Friend (head_node, i++);
int j;
printf ("\t正在添加\n");
printf ("\t請稍候");
fflush (stdout); // 強(qiáng)制刷新緩存,輸出顯示
for (j = 0; j < 3; j++)
{
sleep (1); // Linux 使用sleep,參數(shù)為秒
printf (".");
fflush (stdout); // 強(qiáng)制刷新緩存,輸出顯示
}
printf ("\n");
printf ("\t添加成功!\n");
printf ("\t返回主菜單請輸入1:");
scanf ("%d", &cho);
if (1 == cho)
{
break;
}
else
{
printf ("\t對不起!您的輸入有誤!請重新輸入:");
scanf ("%d", &cho);
break;
}
break;
}
case 2: // 顯示好友信息
{
system ("clear");
printf ("\t*********好友信息********\n");
printf ("\n");
Friend_Information (head_node);
Function = 0;
printf ("\t返回主菜單請輸入1:");
scanf ("%d", &cho);
if (1 == cho)
{
break;
}
else
{
printf ("\t對不起!您的輸入有誤!請重新輸入:");
scanf ("%d", &cho);
break;
}
break;
}
case 3: // 查找好友
{
system ("clear");
printf ("\t*************查找好友*************\n");
printf ("\t請輸入您要查找的好友姓名:");
scanf ("%s", Name);
printf ("\n");
int j;
printf ("\t正在查找\n");
printf ("\t請稍候");
fflush (stdout); // 強(qiáng)制刷新緩存,輸出顯示
for (j = 0; j < 3; j++)
{
sleep (1); // Linux 使用sleep,參數(shù)為秒
printf (".");
fflush (stdout); // 強(qiáng)制刷新緩存,輸出顯示
}
printf ("\n");
Search_Friend (head_node, Name);
printf ("\t返回主菜單請輸入1:");
scanf ("%d", &cho);
if (1 == cho)
{
break;
}
else
{
printf ("\t對不起!您的輸入有誤!請重新輸入:");
scanf ("%d", &cho);
break;
}
break;
}
case 4: //刪除好友
{
system ("clear");
printf ("\t*************刪除好友*************\n");
printf ("\t請輸入要刪除好友的姓名:");
scanf ("%s", Name);
printf ("\n");
Delete_Friend (head_node, Name);
printf ("\t返回主菜單請輸入1:");
scanf ("%d", &cho);
if (1 == cho)
{
break;
}
else
{
printf ("\t對不起!您的輸入有誤!請重新輸入:");
scanf ("%d", &cho);
break;
}
break;
}
case 5: //退出通訊錄
{
Function = 0;
system ("clear");
exit (0);
}
default: //輸入有誤
{
Function = 0;
printf ("\t對不起!您的輸入有誤!請重新輸入:");
scanf ("%d", &Function);
break;
}
}
}
return 0;
}
head.h部分:
#ifndef HEAD_H_
#define HEAD_H_
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h> // sleep函數(shù)頭文件
#define uint unsigned int
#define OK 0
#define ERROR -1
#define MALLOC_ERROR -2
#define N 20
typedef int ElementType;
typedef struct node
{
ElementType ID; // ID號
char Name [N]; // 姓名
char Mobile_Phone [N]; // 手機(jī)號碼
char Home_Address [N]; // 家庭住址
char Company_Tell [N]; // 公司電話
struct node* next; // 節(jié)點(diǎn)指針
}Node;
typedef Node* PNode; //重命名節(jié)點(diǎn)指針類型
//顯示操作界面
int Interface_Display ();
//添加好友信息 (尾插法)
int Add_Friend (PNode head, ElementType num);
//顯示所有好友信息
int Friend_Information (PNode head);
//查找好友
int Search_Friend (PNode head, char* Name);
//刪除好友
void Delete_Friend (PNode head, char* Name);
#endif
head.c的代碼:
#include "head.h"
//顯示操作界面
int Interface_Display ()
{
system ("clear");
printf ("\t************************************** \n");
printf ("\t~ 歡迎使用通訊錄 ~\n");
printf ("\t~ ~\n");
printf ("\t~ 1 >>>>>>>> 添加好友信息 ~\n");
printf ("\t~ 2 >>>>>>>> 列表好友信息 ~\n");
printf ("\t~ 3 >>>>>>>> 搜索好友 ~\n");
printf ("\t~ 4 >>>>>>>> 刪除好友 ~\n");
printf ("\t~ 5 >>>>>>>> 退出 ~\n");
printf ("\t~ ~\n");
printf ("\t~ ~\n");
printf ("\t~ 作者:believe ~\n");
printf ("\t~*************************************~\n");
printf (" \n");
printf (" \n");
printf ("\t請輸入對應(yīng)數(shù)字選擇相應(yīng)功能:");
}
//添加好友信息 (尾插法)
int Add_Friend (PNode head, ElementType num)
{
if (NULL == head)
{
return ERROR;
}
//創(chuàng)建一個新的結(jié)點(diǎn)
PNode p = (PNode) malloc(sizeof(Node)/sizeof(char));
if (NULL == p)
{
return MALLOC_ERROR;
}
//將新數(shù)據(jù)賦給新結(jié)點(diǎn)
system("clear");
printf ("\t*************添加好友***************\n");
p->ID = num;
printf ("\t好友的ID為:%d\n", p->ID);
printf ("\n");
printf ("\t請輸入好友的名字:");
scanf ("%s", p->Name);
printf ("\n");
printf ("\t請輸入好友的手機(jī)號:");
scanf ("%s", p->Mobile_Phone);
printf ("\n");
printf ("\t請輸入好友的家庭住址:");
scanf ("%s", p->Home_Address);
printf ("\n");
printf ("\t請輸入好友的公司電話:");
scanf ("%s", p->Company_Tell);
printf ("\n");
p->next = NULL;
//找到最后一個結(jié)點(diǎn)
PNode Ptmp; //將頭結(jié)點(diǎn)地址給臨時指針Ptmp
Ptmp = head;
while (Ptmp->next)
{
Ptmp = Ptmp->next;
}
Ptmp->next = p;
return OK;
}
//顯示所有好友信息
int Friend_Information (PNode head)
{
if (NULL == head)
{
return ERROR;
}
PNode p = head->next;
printf ("\tID\t姓名\t\t手機(jī)號\t\t住址\t\t\t公司電話\n");
while (p)
{
printf ("\t%d\t%s\t\t%s\t\t%s\t\t\t%s\n", p->ID,
p->Name, p->Mobile_Phone, p->Home_Address,
p->Company_Tell);
p = p->next;
}
putchar('\n');
return OK;
}
//查找好友
int Search_Friend (PNode head, char* Name) //通過名字查找好友
{
PNode p = head;
PNode q = NULL;
if ((NULL != p) && NULL != (p->next))
{
while (p->next)
{
q = p->next;
if ((NULL != q) && 0 == (strcmp(q->Name, Name)))
{
printf ("\t好友信息: \n\tID:%d\n\t姓名: %s\n\t手機(jī)號碼: %s\n\t家庭地址:%s\n\t公司電話: %s\n", q->ID, q->Name, q->Mobile_Phone, q->Home_Address, q->Company_Tell);
}
else
{
printf ("\t對不起,您的通訊錄沒有該好友!\n");
}
p = p->next;
}
}
/* 另一種做法
if (NULL == head)
{
return ERROR;
}
PNode p;
int flag = 1;
for (p = head->next; p != NULL; p = p->next)
{
if (0 == strcmp(p->Name, Name))
{
flag = 0;
printf ("\t好友信息:\n\tID: %d\n\t姓名: %s\n\t手機(jī)號碼: %s\n\t家庭地址: %s\n\t公司電話: %s\n", p->ID, p->Name, p->Mobile_Phone, p->Home_Address, p->Company_Tell);
}
}
fi (flag)
{
printf ("\t對不起,您的通訊錄沒有該好友!\n");
}
putchar('\n');
*/
return OK;
}
//刪除好友
void Delete_Friend (PNode head, char* Name)
{
PNode p = head;
PNode q = NULL;
while (NULL != p && NULL != (p->next))
{
q = p->next;
if (NULL != q && 0 == strcmp(q->Name, Name))
{
p->next = q->next;
free(q);
int j;
printf ("\t正在刪除\n");
printf ("\t請稍候");
fflush (stdout); //強(qiáng)制刷新緩存,輸出顯示
for (j = 0; j < 3; j++)
{
sleep (1); //linux使用sleep,參數(shù)為秒
printf (".");
fflush(stdout); //強(qiáng)制刷新緩存,輸出顯示
}
printf ("\n");
printf ("\t該好友已成功刪除!\n");
}
else if (NULL == q->next && 0 != strcmp(q->Name, Name))
{
printf ("\t您的通訊錄沒有該好友!\n");
}
p = p->next;
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于VS2019 C++項(xiàng)目同時出現(xiàn)LNK2005 和LNK1169 error 的解決辦法
這篇文章主要介紹了關(guān)于VS2019 C++項(xiàng)目同時出現(xiàn)LNK2005 和LNK1169 error 的解決辦法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04
C# interface與delegate效能比較的深入解析
本篇文章是對C#中interface與delegate的效能比較進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
c語言程序設(shè)計(jì)文件操作方法示例(CreateFile和fopen)
c主要的文件操作函數(shù)有:CreateFile,CloseHandle,ReadFile,WriteFile,SetFilePointer,GetFileSize。其中的讀寫操作是以字符為單位,獲得文件大小也是以字符為單位。2013-12-12
基于C++ bitset常用函數(shù)及運(yùn)算符(詳解)
下面小編就為大家?guī)硪黄贑++ bitset常用函數(shù)及運(yùn)算符(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11
C語言深度解剖篇之關(guān)鍵字以及補(bǔ)充內(nèi)容
C語言的關(guān)鍵字共有32個,根據(jù)關(guān)鍵字的作用,可分其為數(shù)據(jù)類型關(guān)鍵字、控制語句關(guān)鍵字、存儲類型關(guān)鍵字和其它關(guān)鍵字四類,這篇文章主要給大家介紹了關(guān)于C語言深度解剖篇之關(guān)鍵字以及補(bǔ)充內(nèi)容的相關(guān)資料,需要的朋友可以參考下2022-06-06
C++ 中將一維數(shù)組轉(zhuǎn)成多維的三種方式示例詳解
這篇文章主要介紹了C++ 中將一維數(shù)組轉(zhuǎn)成多維的三種方式,每種方式結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-12-12
C++實(shí)現(xiàn)基于reactor的百萬級并發(fā)服務(wù)器
本文介紹了基于Reactor模式的百萬級并發(fā)服務(wù)器,使用epoll進(jìn)行高效I/O多路復(fù)用,支持多個端口的監(jiān)聽,并通過回調(diào)機(jī)制處理每個連接的接收和發(fā)送操作,需要的朋友可以參考下2025-02-02

