# 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:
        # write code here
        dummy = ListNode(0) # 定义一个哑变量,方便设置prev和返回最终链表头节点
        dummy.next = head # 将哑变量接在头节点前
        prev = dummy # 设置前置节点,方便找到值后,改变链表
        cur = head # 用来遍历节点,已找到目标节点
        while cur: # 当cur不为None时
            if cur.val == val: # 判断当前cur的值是否为目标值
                prev.next = cur.next # 将前置节点直接接入下一个节点,跳过目标值节点
                break # 找到之后即可跳出循环
            else: # 当前cur不是目标节点
                prev = cur 
                cur = cur.next
				# 将prev和cur向前移动一位
        return dummy.next # 返回哑变量的下一个节点就是新链表的头节点