91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

c語言單鏈表怎么刪除指定節點

小億
128
2024-01-30 09:19:05
欄目: 編程語言

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 

0
沐川县| 天全县| 科技| 拉萨市| 饶阳县| 北票市| 西乌珠穆沁旗| 华宁县| 仲巴县| 阳泉市| 澄城县| 华阴市| 望江县| 上栗县| 大厂| 新余市| 洛宁县| 临夏市| 七台河市| 阿城市| 宁乡县| 分宜县| 南安市| 新蔡县| 中方县| 长泰县| 当阳市| 宜兴市| 介休市| 乌什县| 保康县| 平远县| 铜山县| 天祝| 彰化县| 清水县| 高密市| 新乡县| 崇文区| 陕西省| 固安县|