删除链表中的节点详解

删除链表中的节点

解题代码(java)

class Solution {
    public void deleteNode(ListNode node) {
        node.val = node.next.val;
        node.next = node.next.next;
    }
}

1.正常思路(错误思路)

在这里插入图片描述

$. 正常思路:要删除 node 节点则让 node 之前的节点(2)重新指向 node 之后的节点(4)
*但是!!!
我们无法访问 node 之前的节点,因此也无法改变其指向
【所以此方法无效】

2.正确解题思路

在这里插入图片描述

  • 思路详解:
    因为我们的目的是删除当前 node 节点的值,但不改变其他节点的值,而且我们目前只能访问 node 之后的节点
    所以,我们只需用 node 下一个节点的值覆盖掉当前 node 节点的值,再把下一个节点删掉即可(删除 node 下一个节点用上文提到的正常思路即可)

  • 实现步骤:
    1>.将 node 下一个节点的值覆盖掉当前节点
    2>.将 node 指向(next.next)节点

难点

【逻辑思维转变】

声明

  • 原作者:E.L.E
  • <未经允许不得转载使用,欢迎大家评论>
  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值