欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

237. Delete Node in a Linked List

程序员文章站 2024-02-17 10:32:10
...

给一个结点删除它,但是不知道它的前任结点
因此有一个办法就是将该节点的value和下一个节点的value交换,然后删除下一个结点

# Definition for singly-linked list.
# class ListNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution(object):
    def deleteNode(self, node):
        """
        :type node: ListNode
        :rtype: void Do not return anything, modify node in-place instead.
        """
        node.val, node.next.val = node.next.val, node.val
        node.next = node.next.next

这样其实是麻烦了,就把下一个节点的值赋值过来,然后把下一个结点删掉就好了呀,笨死了

# Definition for singly-linked list.
# class ListNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution(object):
    def deleteNode(self, node):
        """
        :type node: ListNode
        :rtype: void Do not return anything, modify node in-place instead.
        """
        node.val = node.next.val
        node.next = node.next.next