解决方案
方法:与下一个节点交换
从链表里删除一个节点 node
的最常见方法是修改之前节点的 next
指针,使其指向之后的节点。
因为我们无法访问我们想要删除的节点之前的节点,我们始终不能修改该节点的 next
指针。相反,我们必须将想要删除的节点的值替换为它后面节点中的值,然后删除它之后的节点。
因为我们知道要删除的节点不是列表的末尾,所以我们可以保证这种方法是可行的。
复杂度分析
时间和空间复杂度都是:。
有一个单链表的 head
,我们想删除它其中的一个节点 node
。
给你一个需要删除的节点 node
。你将 无法访问 第一个节点 head
。
链表的所有值都是 唯一的,并且保证给定的节点 node
不是链表中的最后一个节点。
删除给定的节点。注意,删除节点并不是指从内存中删除它。这里的意思是:
node
前面的所有值顺序相同。node
后面的所有值顺序相同。自定义测试:
head
和要给出的节点 node
。node
不应该是链表的最后一个节点,而应该是链表中的一个实际节点。
示例 1:
输入:head = [4,5,1,9], node = 5 输出:[4,1,9] 解释:指定链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9
示例 2:
输入:head = [4,5,1,9], node = 1 输出:[4,5,9] 解释:指定链表中值为 1 的第三个节点,那么在调用了你的函数之后,该链表应变为 4 -> 5 -> 9
提示:
[2, 1000]
-1000 <= Node.val <= 1000
node
是 链表中的节点 ,且 不是末尾节点从链表里删除一个节点 node
的最常见方法是修改之前节点的 next
指针,使其指向之后的节点。
因为我们无法访问我们想要删除的节点之前的节点,我们始终不能修改该节点的 next
指针。相反,我们必须将想要删除的节点的值替换为它后面节点中的值,然后删除它之后的节点。
因为我们知道要删除的节点不是列表的末尾,所以我们可以保证这种方法是可行的。
复杂度分析
时间和空间复杂度都是:。