题解 | #删除链表的节点#
删除链表的节点
http://www.nowcoder.com/practice/f9f78ca89ad643c99701a7142bd59f5d
# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
#
# @param head ListNode类
# @param val int整型
# @return ListNode类
#
class Solution:
def deleteNode(self , head: ListNode, val: int) -> ListNode:
#虚拟头节点
dummy = ListNode(-1)
dummy.next = head
cur = dummy
#如果下一个节点不为空
while cur.next != None:
#验证下一个节点是否为目标
if cur.next.val == val:
#是目标,删掉下一个节点
cur.next = cur.next.next
#不是目标,向后查找
else:
cur = cur.next
#返回链表头,即虚拟头节点的后一个节点
return dummy.next