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

删除链表的节点

https://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:
        # write code here
        
        if ( head == None or not head):
            return None

        p = head
        t = p
        q = p.next

        if (head.val == val):
            head = head.next

        while (p.val != val ):
            t = p
            p = q
            q = q.next

        
        if p == None:
            return head

        t.next = q

        return head

第一次提交的时候,通过率36/37。

出现错误的点在于:当删除的结点是第一个结点时,返回为全链。

原因在于没有进入while,没有完成删除,就返回全链了。因此在while前加入if。

但,这道应该还有代码优化空间。

全部评论

相关推荐

11-01 20:03
已编辑
门头沟学院 算法工程师
Amazarashi66:这种也是幸存者偏差了,拿不到这个价的才是大多数
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务