题解 | #删除链表的节点#
删除链表的节点
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。
但,这道应该还有代码优化空间。