c语言单链表怎么删除指定节点

   2024-11-08 5790
核心提示:C语言单链表删除指定节点的步骤如下:首先,需要找到要删除的节点的前一个节点。将前一个节点的next指针指向要删除节点的next指

C语言单链表删除指定节点的步骤如下:

首先,需要找到要删除的节点的前一个节点。将前一个节点的next指针指向要删除节点的next指针,即跳过要删除的节点。释放要删除的节点的内存空间。

具体实现如下:

#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 

 
举报打赏
 
更多>同类维修大全
推荐图文
推荐维修大全
点击排行

网站首页  |  关于我们  |  联系方式网站留言    |  赣ICP备2021007278号