注意链表的前后关系的交替指向,使用next进行实现 题目比较简单,但是是基本的相关操作

# 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
        # 建立一个虚拟节点,如果头结点删除的话
        xuni  = ListNode(None) # 定义一个空链表
        xuni.next = head
        # 党还有下一个节点时
        dangqian = xuni
        while dangqian.next:
            if dangqian.next.val==val:
                dangqian.next = dangqian.next.next
            dangqian=dangqian.next
        return xuni.next