双向链表(2) - 删除节点

本文介绍了一种在双向链表中删除指定节点的方法,并通过示例代码详细解释了该过程。针对不同位置(头节点、中间节点、尾节点)的删除操作提供了具体的实现步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在双向链表中删除一个指定的节点,可以分为下面的这3种情况:

(a) 原始的双向链表

(b) 删除头节点后

(c) 删除中间节点后

(d) 删除尾节点后

具体算法步骤:
假设需要被删除的节点称之为delNode。
1) 如果delNode为头节点,则将头指针指向后续的节点。
2) 如果delNode的前向节点存在,则将前向节点的后向指针置为delNode的后向指针。
3) 如果delNode的后向节点存在,则将后向节点的前向指针置为delNode的前向指针。

#include <iostream>

struct Node {
    int data;
    Node* next; // 指向下一个节点
    Node* prev; // 指向前一个节点
};

/*
实现双向链表中删除一个节点
head --> 链表的头部指针.
delNode  -->  需要被删除的节点
*/
void deleteNode(Node** head, Node* delNode) {
    //是否为空链表
    if (*head == NULL || delNode == NULL)
        return;
    //删除头节点
    if (*head == delNode)
        *head = delNode->next;
    //被删节点不是尾节点
    if (delNode->next != NULL)
        delNode->next->prev = delNode->prev;
    //被删节点不是首节点
    if (delNode->prev != NULL)
        delNode->prev->next = delNode->next;
    delete delNode;
    return;
}

// 给定链表的头指针(head)以及一个整数,插入一个新的节点至链表的头部  
// 之所以传入双指针,因为函数中需要修改链表  
void push(Node** head, int newData) {
    //1. 分配新节点内存  
    Node* newNode = new Node;
    //2. 赋值  
    newNode->data = newData;
    //3. 将原始头节点做为新节点的后向指针,而前向指针置为NULL  
    newNode->next = (*head);
    newNode->prev = NULL;
    //4. 将原始头节点的前向指针置为新的节点  
    if ((*head) != NULL)
        (*head)->prev = newNode;
    //5. 将头指针置为新的节点  
    (*head) = newNode;
}

void printList(Node* head) {
    while (head != NULL) {
        std::cout << " " << head->data << " ";
        head = head->next;
    }
    std::cout << std::endl;
}

int main() {
    //初始化链表为:10<->8<->6<->4<->2<->0
    Node* head = NULL;
    push(&head, 0);
    push(&head, 2);
    push(&head, 4);
    push(&head, 6);
    push(&head, 8);
    push(&head, 10);

    std::cout << "Original DLL is: " << std::endl;
    printList(head);

    //删除首节点10
    deleteNode(&head, head);
    //删除中间节点4
    deleteNode(&head, head->next->next);
    //删除尾节点0
    deleteNode(&head, head->next->next->next);

    std::cout << "New DLL is: " << std::endl;
    printList(head);
    return 0;
}

运行结果:
Original DLL is:
 10  8  6  4  2  0
New DLL is:
 8  6  2


时间复杂度: O(n)

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

水草

您的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值