本文实例为大家分享了C语言链表实现简易通讯录的具体代码,供大家参考,具体内容如下
链表实现通讯录功能:
1.添加–(输入 姓名,电话)
2.删除-- (输入人名,删除该人)
3.查询-- (直接打印所有联系人)
4.修改-- (输入人名,修改电话)
运行效果:
代码分主函数块 和 链表块:
Linklist.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
|
#ifndef LINKLIST_H_INCLUDED #define LINKLIST_H_INCLUDED //链表节点 typedef struct Node { char name[10]; //名字 char data[12]; //电话 struct Node* next; //上一个节点 struct Node* prev; //下一个节点 }Node; //链表 typedef struct LinkList { Node* head; //链表头节点 Node* tail; //链表尾节点 int len; //链表长度 }LinkList; //创造空节点 Node* creatNode(); //添加 void AddNode(LinkList* List, char * data, char * name); //删除 int DeleteNode(LinkList* List, char * name); //查询 void CheckList(LinkList* List); //修改 int UpdataNode(LinkList* List, char * data, char * name); #endif // LINKLIST_H_INCLUDED |
Linklist.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
|
#include <stdio.h> #include "LinkList.h" #include <stdlib.h> #include <string.h> Node* creatNode() { //申请空间 Node* ptr=(Node* ) malloc ( sizeof (Node)); //初始化 memset (ptr->data,0, sizeof (ptr->data)); memset (ptr->name,0, sizeof (ptr->name)); ptr->next=NULL; ptr->prev=NULL; return ptr; } void AddNode(LinkList* List, char * data, char * name) { Node* ptr=creatNode(); if (List->len==0) //增加时链表还没有节点 { strcpy (ptr->data,data); strcpy (ptr->name,name); List->head=ptr; List->tail=ptr; List->len++; } else { List->len++; strcpy (ptr->data,data); strcpy (ptr->name,name); ptr->prev=List->tail; List->tail->next=ptr; List->tail=ptr; } } int DeleteNode(LinkList* List, char * name) { Node* ptr=List->head; int it=1; while (it<=List->len) { if ( strcmp (ptr->name,name)==0) { if (it==List->len) //删除的是尾节点 { ptr->prev->next=NULL; List->tail=ptr->prev; List->len--; } else if (it==1) //删除的是头节点 { ptr->next->prev=NULL; List->head=ptr->next; List->len--; } else { ptr->next->prev=ptr->prev; ptr->prev->next=ptr->next; List->len--; } return 1; } ptr=ptr->next; it++; } return 0; } void CheckList(LinkList* List) { Node* ptr=List->head; int it = 0; //遍历,类似迭代器 while (it<List->len) { printf ( "%s\t %s\n" ,ptr->name,ptr->data); ptr=ptr->next; it++; } } int UpdataNode(LinkList* List, char * data, char * name) { Node* ptr=List->head; int it=1; while (it<=List->len) { if ( strcmp (ptr->name,name)==0) //找到名字,修改电话 { strcpy (ptr->data,data); return 1; } ptr=ptr->next; it++; } return 0; } |
main.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
|
#include <stdio.h> #include "LinkList.h" int main() { int choose; LinkList list1 = {NULL,NULL,0}; //方便调试,先输入三个人 AddNode(&list1, "15181512167" , "chen" ); AddNode(&list1, "12345678910" , "li" ); AddNode(&list1, "12456878216" , "zhang" ); while (1) { printf ( "1.添加 2.删除 3.查询 4.修改 0.退出\n" ); scanf ( "%d" ,&choose); switch (choose) { case 1: { char data[12]; char name[10]; printf ( "输入名字: " ); scanf ( "%s" ,name); printf ( "输入电话: " ); scanf ( "%s" ,data); AddNode(&list1,data,name); printf ( "----------------\n" ); break ; } case 2: { char name1[10]; CheckList(&list1); printf ( "选择删除的人: " ); scanf ( "%s" ,name1); if (DeleteNode(&list1,name1)) { printf ( "删除成功 \n" ); } else { printf ( "删除失败 \n" ); } printf ( "----------------\n" ); break ; } case 3: { CheckList(&list1); printf ( "----------------\n" ); break ; } case 4: { char name[10]; char data[12]; CheckList(&list1); printf ( "输入你要修改的人: " ); scanf ( "%s" ,name); printf ( "输入修改后的电话号:" ); scanf ( "%s" ,data); if (UpdataNode(&list1,data,name)) { printf ( "修改成功\n" ); } else { printf ( "修改失败\n" ); } printf ( "----------------\n" ); break ; } case 0: { printf ( "----------------\n" ); exit (0); } } } return 0; } |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/CY_612/article/details/113768424