题解 | #删除链表的节点#

删除链表的节点

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 
全部评论

相关推荐

头像
09-29 16:18
门头沟学院 Java
点赞 评论 收藏
分享
无情咸鱼王的秋招日记之薛定谔的Offer:好拒信,偷了,希望有机会用到
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务