删除链表中节点(只给待删除节点)

题目:请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点,你将只被给定要求被删除的节点。

输入:head = [4,5,1,9], node = 5

输出:[4,1,9]

思路:与203题不同,此题只给定被删除的节点,而不给定头节点,直接改变节点的指向即可

1
2
3
4
5
6
7
8
9
10
class :
def deleteNode(self, node):
"""
:type node: ListNode
:rtype: void Do not return anything, modify node in-place instead.
"""
if not node:
return node
node.val = node.next.val
node.next = node.next.next