C语言实现简易通讯录

时间:2022-11-27 21:11:04

本文实例为大家分享了C语言实现简易通讯录的具体代码,供大家参考,具体内容如下

功能描述:

1、存储联系人的相关信息,包括姓名、性别、电话号码、备注
2、可输出通讯录全部信息
3、清空通讯录的
4、用户交互界面
5、插入新联系人信息
6、查找联系人,包括“按姓名查找”和“按电话号查找”两种
7、删除联系人,包括“按姓名删除”和“按电话号删除”两种
8、按性别筛选联系人信息

在本次通讯录的编写代码中,涉及到了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
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define SIZE 20
#define OK 1
#define Error 0
typedef struct Node //定义一个存储数据的结构体
{           
 char name[SIZE];
 char s;
 long int number;
 char remark[SIZE];
 struct Node *next;
}Node;
typedef struct Node *LinkList; //定义了结构体指针
 
/************创建一个空的结点,作为头结点***************/
LinkList CreateEmptyLinkList()
{
 LinkList p;
 p=(LinkList)malloc(sizeof(Node));  //手动申请一个堆区的地址,为结点提供空间
 if(p==NULL)
 {
 printf("CreateEmptyLinkList Error\n");
 exit(0);
 }
 p->next=NULL;
 return p;
}
 
 
/************头插法添加新的联系人************************/
 
int CreateLinkList(LinkList Q)
{
 LinkList p;
 char name[SIZE],s,remark[SIZE];
 long int num;
 p=(LinkList)malloc(sizeof(Node));
 if(p==NULL)
 {
 printf("CreateLinkList Error\n");
 return Error;
 }
 printf("请输入姓名:");
 scanf("%s",name);
 strcpy(p->name,name);
 printf("请输入性别(m/男,f/女):");
 scanf("%s",&s);
 while(s!='m'&&s!='f')
 {
 printf("输入错误\n");
 printf("请输入性别(m/男,f/女):");
 scanf("%s",&s);
 }
 printf("请输入电话号码:");
 scanf("%ld",&num);
 printf("请输入备注:");
 scanf("%s",remark);
 p->s=s;
 p->number=num;
 strcpy(p->remark,remark);
 p->next=Q->next;
 Q->next=p;
 return OK;
}
/*********************制作原始联系人信息****************/
int FirstCreateLinkList(LinkList Q)
{
 LinkList x,y,z;
 x=(LinkList)malloc(sizeof(Node));
 if(x==NULL)
 {
 printf("CreateLinkList Error\n");
 return Error;
 }
 strcpy(x->name,"LiLi");
 x->s='f';
 x->number=10110;
 x->next=Q->next;
 strcpy(x->remark,"LiLi");
 Q->next=x;
 y=(LinkList)malloc(sizeof(Node));
 if(y==NULL)
 {
 printf("CreateLinkList Error\n");
 return Error;
 }
 strcpy(y->name,"NaNa");
 y->s='f';
 y->number=11100;
 strcpy(y->remark,"NaNa");
 y->next=Q->next;
 Q->next=y;
 z=(LinkList)malloc(sizeof(Node));
 if(z==NULL)
 {
 printf("CreateLinkList Error\n");
 return Error;
 }
 strcpy(z->name,"LiuLiu");
 z->s='m';
 z->number=10000;
 strcpy(z->remark,"LiuLiu");
 z->next=Q->next;
 Q->next=z;
 return OK;
}
/*****************按姓名删除一个联系人****************************/
 
int DeleteNameLinkList(LinkList L,char name1[SIZE])
{
 LinkList p,q;
 p=L;
 while(p->next && strcmp(p->next->name,name1))
 {
 p=p->next;
 }
 if(!p->next)
 {
 printf("该通讯录没有要删除的联系人,删除失败!\n");
 return Error;
 }
 else
 {
 q=p->next;
 printf("已删除联系人:\n");
 printf("姓名:%s\n",q->name);
 if(q->s=='m')
 printf("性别:男\n");
 else
 printf("性别:女\n");
 printf("电话号码:%ld\n",q->number);
 printf("备注:%s\n",q->remark);
 
 p->next=q->next;
 free(q);
 return OK;
 }
}
/*****************按号码删除一个联系人****************************/
 
int DeleteNumLinkList(LinkList L,long int j)
{
 LinkList p,q;
 p=L;
 while((p->next->number!=j)&&((p->next)!=NULL))
 {
 p=p->next;
 if((p->next)==NULL)
 {
  printf("该通讯录没有要删除的联系人,删除失败!\n");
  return Error;
 }
 }
 q=p->next;
 printf("已删除联系人:\n");
 printf("姓名:%s\n",q->name);
 if(q->s=='m')
 printf("性别:男\n");
 else
 printf("性别:女\n");
 printf("电话号码:%ld\n",q->number);
 printf("备注:%s\n",q->remark);
 p->next=q->next;
 free(q);
 return OK;
}
 
/******************按姓名查找一个联系人****************************/
int FindNameLinkList(LinkList L,char name2[SIZE])
{
 LinkList p,q;
 p=L;
 while(strcmp(p->next->name,name2)!=0&&(p->next!=NULL))
 {
 p=p->next;
 if(p->next==NULL)
 {
  printf("该通讯录没有您要找的人,查找失败\n");
  return Error;
 }
 }
 q=p->next;
 printf("找到记录:\n");
 printf("姓名:%s\n",q->name);
 if(q->s=='m')
 printf("性别:男\n");
 else
 printf("性别:女\n");
 printf("电话号码:%ld\n",q->number);
 printf("备注:%s\n",q->remark);
 printf("*********************************\n");
 return OK;
}
/******************按号码查找一个联系人****************************/
int FindNumLinkList(LinkList L,long int j)
{
 LinkList p,q;
 p=L;
 while((p->next->number!=j)&&((p->next)!=NULL))
 {
 p=p->next;
 if((p->next)==NULL)
 {
  printf("该通讯录没有您要找的人,查找失败\n");
  return Error;
 }
 }
 q=p->next;
 printf("找到记录:\n");
 printf("姓名:%s\n",q->name);
 if(q->s=='m')
 printf("性别:男\n");
 else
 printf("性别:女\n");
 printf("电话号码:%ld\n",q->number);
 printf("备注:%s\n",q->remark);
 printf("*********************************\n");
 return OK;
}
/******************查找一个联系人****************************/
int FindLinkList(LinkList L)
{
 LinkList head = L;  
 printf("*********************************\n");
 printf("请输入查找联系人的方式:\n");
 printf("1:按姓名\n");
 printf("2:按号码\n");
 printf("0:返回\n");
 printf("*********************************\n");
 printf("请选择:");
 int k=3;  //确保下面while循环运行
 while(k)
 {
 scanf("%d",&k);
 char Delname1[SIZE];
 long int N;
 if(k>2||k<0)
 {
  printf("输入错误,请重新输入:");
  scanf("%d",&k);
  while(getchar()!='\n')
  printf("\n");
 }
 switch(k)
 {
  case 1:
  printf("请输入姓名:");
  scanf("%s",Delname1);
  FindNameLinkList(head,Delname1);
  k=0;
  break;
  case 2:
  printf("请输入号码:");
  scanf("%ld",&N);
  FindNumLinkList(head,N);
  k=0;
  break;
 }
 
 }
}
/********************清空联系人信息*************************/
int ClearLinkList(LinkList L)
{
 LinkList p,q;
 p=L->next;
 while(p)
 {
 q=p->next;
 free(p);
 p=q;
 }
 L->next=NULL;
 printf("清空所有联系人成功\n");
 return OK;
}
 
/*********************筛选所有男性联系人**********************/
int ScreenMaleLinkList(LinkList L)
{
 LinkList p;
 p=L->next;
 int i=0;
 while(p)
 {
 if(p->s=='m')
 {
  printf("姓名:%s\n",p->name);
  if(p->s=='m')
  printf("性别:男\n");
  else
  printf("性别:女\n");
  printf("电话号码:%ld\n",p->number);
  printf("备注:%s\n",p->remark);
  printf("*********************************\n");
 }
 p=p->next;
 i++;
 }
 if(i==0&&!p)
 {
 printf("无男性联系人\n");
 }
 return OK;
}
/*********************筛选所女性联系人**********************/
int ScreenFemaleLinkList(LinkList L)
{
 LinkList p;
 p=L->next;
 int i=0;
 while(p)
 {
 if(p->s=='f')
 {
  printf("姓名:%s\n",p->name);
  if(p->s=='m')
  printf("性别:男\n");
  else
  printf("性别:女\n");
  printf("电话号码:%ld\n",p->number);
  printf("备注:%s\n",p->remark);
  printf("*********************************\n");
 }
 p=p->next;
 i++;
 }
 if(i==0&&!p)
 {
 printf("无女性联系人\n");
 }
 return OK;
}
/************************通讯录功能界面*****************/
void FunctionalInterface()
{
 system ("clear");
 printf("*********************************\n");
 printf("欢迎使用Linux通讯录!\n");
 printf("*********************************\n");
 printf("1:输出全部联系人信息\n");
 printf("2:插入新的联系人\n");
 printf("3:删除一个联系人\n");
 printf("4:查找某个联系人\n");
 printf("5:清空全部联系人信息\n");
 printf("6:筛选全部男性联系人信息\n");
 printf("7:筛选全部女性联系人信息\n");
 printf("0:退出\n");
 printf("*********************************\n");
}
/*****************删除一个联系人****************************/
 
int DeleteLinkList(LinkList L)
{
 LinkList head = L;
 printf("*********************************\n");
 printf("请输入删除联系人的方式:\n");
 printf("1:按姓名\n");
 printf("2:按号码\n");
 printf("0:返回\n");
 printf("*********************************\n");
 printf("请选择:");
 int i=3;
 while(i)
 {
 scanf("%d",&i);
 char Delname[SIZE];
 long int j;
 if(i>2||i<0)
 {
  printf("输入错误,请重新输入:");
  scanf("%d",&i);
  while(getchar()!='\n')
  printf("\n");
 }
 switch(i)
 {
  case 1:
  printf("请输入姓名:");
  scanf("%s",Delname);
  DeleteNameLinkList(head,Delname);
  i=0;
  break;
  case 2:
  printf("请输入号码:");
  scanf("%ld",&j);
  DeleteNumLinkList(head,j);
  i=0;
  break;
 }
 
 }
 
}
/*******************遍历打印整个链表**********************/
int PrintfLinkList(LinkList L)
{
 LinkList p,q;
 q=p=L->next;
 int i=0;
 while(q)
 {
 i++;
 q=q->next;
 if(i==0&&!p)
 {
 printf("无联系人\n");
 }
 }
 printf("共有%d个联系人\n",i);
 while(p)
 {
 printf("*********************************\n");
 printf("姓名:%s\n",p->name);
 if(p->s=='m')
  printf("性别:男\n");
 else
  printf("性别:女\n");
 printf("电话号码:%ld\n",p->number);
 printf("备注:%s\n",p->remark);
 p=p->next;
 }
 printf("*********************************\n");
 return OK;
 
}
 
int main()
{
 int a;
 LinkList head;
 head=CreateEmptyLinkList();
 FirstCreateLinkList(head);
 FunctionalInterface();
 while(a)
 {
 printf("请输入您要选择的功能:");
 scanf("%d",&a);
 if(a>7||a<0)
 {
  printf("输入错误,请重新输入:");
  scanf("%d",&a);
  while(getchar()!='\n')
  printf("\n");
 }
 switch(a)
 {
  case 1:
  PrintfLinkList(head);
  break;
  case 2:
  CreateLinkList(head);
  break;
  case 3:
  DeleteLinkList(head);
  break;
  case 4:
  FindLinkList(head);
  break;
  case 5:
  ClearLinkList(head);
  break;
  case 6:
  ScreenMaleLinkList(head);
  break;
  case 7:
  ScreenFemaleLinkList(head);
  break;
  }
 if(a!=0)
 {
  printf("请按回车键继续:");
  getchar();
  if(getchar()=='\n')
  FunctionalInterface();
 }
 }
 printf("欢迎再次使用\n");
 return 0;
}

以上均为自己编写,个人能力有限,如有错误,还请各位批评指正。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/qq_35623907/article/details/80245396