C语言链表基本操作

简介: C语言链表基本操作
1. 
2. #include <stdio.h>
3. #include <stdlib.h>
4. 
5. typedef struct Node{
6.  int data;           //数据域
7.  struct Node *next;    //指针域
8. }Node;
9. 
10. 
11. Node* createList()
12. {
13.     Node* headNode= (Node *)malloc(sizeof(Node));
14.   headNode->next = NULL;
15. return headNode;
16. }
17. 
18. //创建节点
19. Node* createNode(int data)
20. {
21.   Node* newNode = (Node *)malloc(sizeof(Node)); //headNode成为了结构体变量
22.   newNode->data = data;
23.   newNode->next = NULL;
24.   return newNode;
25. }
26. 
27. 
28. 
29. //打印链表
30. void printList(Node* headNode)
31. {
32.   Node* pMove = headNode->next;
33.   while (pMove)
34.   {
35.     printf("%d\t", pMove->data);
36.     pMove = pMove->next;
37.   }
38.   printf("\n");
39. }
40. 
41. //头插节点,参数:插入那个节点,插入节点的数据是多少
42. void PushFront(Node* headNode, int data)
43. {
44.   //1创建插入的节点
45.   Node *newNode = createNode(data);
46.   newNode->next = headNode->next;
47.   headNode->next = newNode;
48. }
49. 
50. //从头部删除节点
51. void PopFront(Node* headNode)
52. {
53.   Node* pDel = headNode->next;
54.   headNode->next = headNode->next->next;
55.   free(pDel);
56. }
57. 
58. //尾插节点
59. void PushBack(Node* headNode, int data)
60. {
61.   Node* newNode = createNode(data);
62. 
63.   while (headNode->next)
64.     headNode = headNode->next;
65. 
66.   headNode->next = newNode;
67. }
68. 
69. //尾删节点
70. /*
71. 考虑三种情况
72. 链表为空时,直接返回
73. 链表中只有一个节点时,将headNode指向NULL
74. 链表中有多个节点时,遍历一遍链表,找到最后一个节点,并保存最后一个节点前一个节点的信息
75. */
76. void PopBack(Node *headNode)
77. {
78.   if (NULL == headNode)
79.   {
80.     return;
81.   }
82.   else if (NULL == headNode->next)
83.   {
84.     //free(headNode->next);
85.     headNode = NULL;
86.   }
87.   else
88.   {
89.     Node *pCur = headNode->next;
90.     Node *prev = headNode;
91.     while (pCur->next != NULL)
92.     {
93.       prev = pCur;
94.       pCur = pCur->next;
95.     }
96.     free(pCur);
97.     prev->next = NULL;
98.   }
99. }
100. 
101. //链表的删除:指定位置删除
102. void deleteNode(Node* headNode, int posData)
103. {
104.  Node* p = headNode->next;
105.  Node* pPre = headNode;
106.  if (p == NULL)
107.    printf("链表为空,无法删除\n");
108.  else
109.  {
110.    while (p->data != posData)
111.    {
112.      pPre = p;
113.      p = p->next;
114.      if (p == NULL)
115.      {
116.        printf("没有找到相关信息,无法删除\n");
117.        return;
118.      }
119.    }
120.    pPre->next = p->next;
121.    free(p);
122.  }
123. }
124. 
125. //反转链表
126. Node* reverseList(struct Node* headNode)
127. {
128.  if ((headNode == NULL) || (headNode->next == NULL))
129.    return headNode;
130.  else
131.  {
132.    Node* newHead = reverseList(headNode->next);
133.    headNode->next->next = headNode;
134.    headNode->next = NULL;
135.    return newHead;
136.  }
137. }
138. 
139. //删除链表的倒数第n个节点
140. Node* removeNthFromEnd(Node* headNode, int n) 
141. {
142.  //如果链表结点个数为0,直接返回 
143.  if (n == 0){
144.    return headNode;
145.  }
146. 
147.  //fastp为快指针,slowp为慢指针(用于指向待删除结点),slowp指向待删除结点的前驱结点。 
148.  Node *fastp = NULL, *slowp = NULL, *slowq = NULL;
149.  //先让快指针后跑n个结点 
150.  for (fastp = headNode; n>0; fastp = fastp->next, n--);
151.  slowp = headNode;
152.  //然后让快指针和慢指针一起向后跑,slowp为slowq的联动指针
153.  //当快指针跑到NULL时停止,这时候快指针一定指向待删除结点 
154.  while (fastp){
155.    slowq = slowp;
156.    slowp = slowp->next;
157.    fastp = fastp->next;
158.  }
159.  //如果要删除的结点为头结点,需要单独处理。否则,利用slowq->next=slowp->next即可删除结点 
160.  if (slowp == headNode){
161.    headNode = headNode->next;
162.  }
163.  else{
164.    slowq->next = slowp->next;
165.    free(slowp);
166.  }
167.  return headNode;
168. }
169. 
170. int main(void)
171. {
172.     Node* list = createList();
173. 
174.  PushFront(list, 1);
175.  PushFront(list, 2);
176.  PushFront(list, 3);
177.  PushFront(list, 4);
178.  PushFront(list, 5);
179.  printList(list);
180. 
181.  deleteNode(list, 3);
182. 
183.  //removeNthFromEnd(list, 2);
184.  printList(list);
185. 
186.  system("pause");
187.  return 0;
188. }


相关文章
|
23天前
|
存储 算法 C语言
【C语言】深入浅出:C语言链表的全面解析
链表是一种重要的基础数据结构,适用于频繁的插入和删除操作。通过本篇详细讲解了单链表、双向链表和循环链表的概念和实现,以及各类常用操作的示例代码。掌握链表的使用对于理解更复杂的数据结构和算法具有重要意义。
227 6
|
27天前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
53 5
|
1月前
|
存储 C语言
【数据结构】手把手教你单链表(c语言)(附源码)
本文介绍了单链表的基本概念、结构定义及其实现方法。单链表是一种内存地址不连续但逻辑顺序连续的数据结构,每个节点包含数据域和指针域。文章详细讲解了单链表的常见操作,如头插、尾插、头删、尾删、查找、指定位置插入和删除等,并提供了完整的C语言代码示例。通过学习单链表,可以更好地理解数据结构的底层逻辑,提高编程能力。
94 4
|
2月前
|
存储 缓存 C语言
C语言:链表和数组有什么区别
C语言中,链表和数组是两种常用的数据结构。数组是一种线性结构,元素在内存中连续存储,通过下标访问,适合随机访问且大小固定的情况。链表由一系列不连续的节点组成,每个节点存储数据和指向下一个节点的指针,适用于频繁插入和删除操作的场景,链表的大小可以动态变化。
|
2月前
|
C语言
无头链表再封装方式实现 (C语言描述)
如何在C语言中实现无头链表的再封装,包括创建节点和链表、插入和删除操作、查找和打印链表以及销毁链表的函数。
36 0
|
2月前
|
C语言
C语言链式结构之有头单链表再封装写法
本文介绍了如何使用C语言对有头单链表进行封装,包括节点的创建、链表的初始化、数据的插入和删除,以及链表的打印等功能。
24 1
|
2月前
|
C语言
C语言结构体链式结构之有头单链表
文章提供了一个C语言实现的有头单链表的完整代码,包括创建链表、插入、删除和打印等基本操作。
36 1
|
2月前
|
测试技术 C语言
单链表之无头链表(C语言版)
本文详细介绍了使用C语言实现无头单链表的方法,包括节点和链表结构的定义、链表的创建与销毁、节点的插入与删除,以及链表的打印等功能。文章通过具体的代码示例,展示了如何在无头链表中进行头插法、尾插法、自定义位置插入和删除,以及如何清空和销毁链表。
49 0
单链表之无头链表(C语言版)
|
1月前
|
C语言
【数据结构】双向带头循环链表(c语言)(附源码)
本文介绍了双向带头循环链表的概念和实现。双向带头循环链表具有三个关键点:双向、带头和循环。与单链表相比,它的头插、尾插、头删、尾删等操作的时间复杂度均为O(1),提高了运行效率。文章详细讲解了链表的结构定义、方法声明和实现,包括创建新节点、初始化、打印、判断是否为空、插入和删除节点等操作。最后提供了完整的代码示例。
68 0
|
2月前
|
C语言
无头链表二级指针方式实现(C语言描述)
本文介绍了如何在C语言中使用二级指针实现无头链表,并提供了创建节点、插入、删除、查找、销毁链表等操作的函数实现,以及一个示例程序来演示这些操作。
37 0