C语言单链表删除指定节点的步骤如下:
具体实现如下:
#include <stdio.h>
#include <stdlib.h>
// 定义链表节点结构体
typedef struct Node {
int data; // 数据域
struct Node* next; // 指针域
} Node;
// 删除指定节点
void deleteNode(Node* head, int value) {
Node* prev = head; // 前一个节点
Node* current = head->next; // 当前节点
// 遍历链表,查找要删除的节点
while (current != NULL) {
if (current->data == value) {
break;
}
prev = current;
current = current->next;
}
// 当前节点为NULL,表示没有找到要删除的节点
if (current == NULL) {
printf("Node with value %d not found.\n", value);
return;
}
// 找到要删除的节点,删除
prev->next = current->next;
free(current);
}
// 打印链表
void printList(Node* head) {
Node* current = head->next; // 从第一个节点开始打印
// 遍历链表,依次打印节点的数据
while (current != NULL) {
printf("%d ", current->data);
current = current->next;
}
printf("\n");
}
int main() {
// 创建链表 1->2->3->4->5
Node* head = (Node*)malloc(sizeof(Node)); // 头节点
Node* node1 = (Node*)malloc(sizeof(Node)); // 第一个节点
Node* node2 = (Node*)malloc(sizeof(Node)); // 第二个节点
Node* node3 = (Node*)malloc(sizeof(Node)); // 第三个节点
Node* node4 = (Node*)malloc(sizeof(Node)); // 第四个节点
head->next = node1;
node1->data = 1;
node1->next = node2;
node2->data = 2;
node2->next = node3;
node3->data = 3;
node3->next = node4;
node4->data = 4;
node4->next = NULL;
printf("Original list: ");
printList(head);
// 删除节点2
deleteNode(head, 2);
printf("List after deletion: ");
printList(head);
// 释放内存
free(node4);
free(node3);
free(node2);
free(node1);
free(head);
return 0;
}
以上代码中,首先创建了一个包含5个节点的链表,然后调用deleteNode()
函数删除了节点2,最后打印链表,输出结果为:
Original list: 1 2 3 4
List after deletion: 1 3 4