- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章C语言实现简单电子通讯录由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
本文实例为大家分享了C语言实现电子通讯录的具体代码,供大家参考,具体内容如下 。
制作一个电子通讯录,通过该通讯录能录入好友ID号、姓名(英文)、手 机号码,家庭住址,公司电话。** 原理:分成5个模块,将模块功能实现写入头文件中。主函数部分代码: 显示函数部分,在Markdown里对不齐,意思就这样,将就一下=。= 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
|
/*******************************************************************
需求:制作一个电子通讯录,通过该通讯录能录入好友ID号、姓名(英文)、手
机号码,家庭住址,公司电话。
模块:
主界面:主要显示软件功能,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);
// 强制刷新缓存,输出显示
for
(j = 0; j < 3; j++)
{
sleep (1);
// Linux 使用sleep,参数为秒
printf
(
"."
);
fflush
(stdout);
// 强制刷新缓存,输出显示
}
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);
// 强制刷新缓存,输出显示
for
(j = 0; j < 3; j++)
{
sleep (1);
// Linux 使用sleep,参数为秒
printf
(
"."
);
fflush
(stdout);
// 强制刷新缓存,输出显示
}
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部分:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
#ifndef HEAD_H_
#define HEAD_H_
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h> // sleep函数头文件
#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];
// 手机号码
char
Home_Address [N];
// 家庭住址
char
Company_Tell [N];
// 公司电话
struct
node* next;
// 节点指针
}Node;
typedef
Node* PNode;
//重命名节点指针类型
//显示操作界面
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的代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
|
#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请输入对应数字选择相应功能:"
);
}
//添加好友信息 (尾插法)
int
Add_Friend (PNode head, ElementType num)
{
if
(NULL == head)
{
return
ERROR;
}
//创建一个新的结点
PNode p = (PNode)
malloc
(
sizeof
(Node)/
sizeof
(
char
));
if
(NULL == p)
{
return
MALLOC_ERROR;
}
//将新数据赋给新结点
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请输入好友的手机号:"
);
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;
//找到最后一个结点
PNode Ptmp;
//将头结点地址给临时指针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手机号\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手机号码: %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手机号码: %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);
//强制刷新缓存,输出显示
for
(j = 0; j < 3; j++)
{
sleep (1);
//linux使用sleep,参数为秒
printf
(
"."
);
fflush
(stdout);
//强制刷新缓存,输出显示
}
printf
(
"\n"
);
printf
(
"\t该好友已成功删除!\n"
);
}
else
if
(NULL == q->next && 0 !=
strcmp
(q->Name, Name))
{
printf
(
"\t您的通讯录没有该好友!\n"
);
}
p = p->next;
}
}
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:https://blog.csdn.net/believe_s/article/details/76167777 。
最后此篇关于C语言实现简单电子通讯录的文章就讲到这里了,如果你想了解更多关于C语言实现简单电子通讯录的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
您好,我是个菜鸟,如果您对此有任何帮助,我将不胜感激。我正在尝试使用用户保存在他们地址簿中的数据,之后我想让他们选择使用该地址进行递送。 这是我的地址 Controller class Address
我目前正在为我的公司开发一个网络应用程序。在此应用程序中,有一个表单,其中的输入字段包含有关联系人的信息。我想创建一个按钮,单击即可在地址簿中创建联系人。 是否可以使用 JavaScript 或其他网
在隐藏通讯录界面之前,是否可以一次选择多个联系人?还是每次地址簿界面出现时实际上只需要选择一个联系人? 最佳答案 是的,Whatsapp做到了。 如果您需要一个示例,请参见以下示例: MultiCon
我正在尝试获取 Android 中联系人的所有电话号码。我的代码如下所示: ContentResolver cr = context.getContentResolver(); String[] pr
我正在为域中的所有用户构建一个表。我让表格正常工作,并在其中为我的分页添加了一些代码,但现在我不断收到错误... //connection $conn = new mysqli($servername
我正在开发一个可以访问 iPhone 通讯录的应用程序。模拟器仅包含几个示例条目。我想找到一个包含数千个条目的示例地址簿字符集(英语、中文、阿拉伯语等)来全面测试我的应用程序。自己填写地址簿将花费永远
是否有任何 android API 可以提取 vcard 3.0 格式的联系人?我遇到了一个开源 vcard 项目 android-vcard 但在用法示例中提到了以下注释。 重要提示:如果您正在为
我的应用程序能够在应用程序的不同实例之间共享其内容,即有一个按钮可以让我将文档附加到电子邮件并将其发送给应用程序的另一个用户。当他们收到此文件时,它会在他们的应用程序实例中打开。这一切正常。 但是,在
我正在开发 iPhone 联系人管理应用程序。一位用户报告说他的所有联系人都是重复的。当他选择特定来源时,联系人不会重复。显然,这是因为他的地址簿同步了两次:一次是与他 PC 上的 iTunes 同步
我有两个继承自 UIViewController 的 Objective-C 类,我正在尝试一种不同的方法来学习如何与 iPhone 的地址簿进行交互。 example Apple 假设一切都在一个类
我想添加在 iOS 通讯录中保存联系人(电话号码、姓名、地址和电子邮件)的功能,方法是单击我的应用程序中的一个按钮!我该怎么做? 最佳答案 非常简单,只需按照以下步骤操作, 首先,您需要导入以下框架,
我正在使用新的 API 在我的手机上插入/更新联系人,我正在使用这种方法来更新它们.. String selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.
我目前正在开发 Contact Importer 网络应用程序(使用 PHP),这样我就可以从 Gmail、Yahoo 等网站的用户帐户中获取电子邮件地址,并将它们用于我自己的邪恶目的。开个玩笑,我的
我与 Google 通讯录合作,一切顺利。但一个小时后,我需要手动刷新授予的访问权限。据此SO question我应该能够通过这个调用更新我的 refresh_token : refresh_toke
我正在使用以下代码获取 google 联系人姓名和电话号码。授权页面本身没有正常显示错误,如“您请求的页面无效”。 :( 请帮我解决这个问题... ` google.load("gdata",
正在尝试使用 google contacts api,如果我使用的话 https://www.google.com/m8/feeds/contacts/default/full 我有 25 个联系人,
由于 Google 停止了对旧版 Auth 的支持,现在我们必须使用 oAuth 2,我们简单的桌面应用程序无法再从我的 Google 帐户读取联系人。 很好 - 我明白这一点,但是这个新的 oAut
我想以编程方式将联系人直接保存到 iOS 设备的地址簿。 我该怎么做? 最佳答案 这是一个小例子: CFErrorRef error = NULL; NSLog(@"%@", [self descri
我正在尝试使用 Javascript 提取我在 Google 通讯录 ( https://contacts.google.com ) 上的联系人。为此,我需要将联系人面板滚动到底部,以便获取所有页面源
我目前正在开发一个 VoIP 应用程序,但我真的很受地址簿困扰。 由于自定义设计, native 地址簿不适合我的应用程序。此外,我想添加一些 native 地址簿中不存在的额外数据。但这会导致一些问
我是一名优秀的程序员,十分优秀!