C言語で単方向リストから特定のノードを削除する方法は?

C言語で指定されたノードを削除する単方向リストの手順は次のとおりです。

  1. 最初に、削除するノードの直前のノードを見つける必要があります。
  2. 前のノードのnextポインタを削除するノードのnextポインタに向け、削除するノードをスキップする。
  3. ノードを削除するときに、そのメモリ空間を解放してください。

実際の実装は以下の通りです。

#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 
bannerAds