Leetcode LinkedList 题型总结(2)

这里我把删除有关的放在一起讲.

Remove Linked List Elements
删除就是把要删除的节点前一个的 next 指向别的, 把它自己的 next 连上去

class Solution:
    # @param {ListNode} head
    # @param {integer} val
    # @return {ListNode}
    def removeElements(self, head, val):
        head2 = ListNode(-1)
        head2.next = head
        pointer = head2

        while pointer and pointer.next:
            if pointer.next.val == val:
                pointer.next = pointer.next.next
            else:   pointer = pointer.next

        return head2.next

Remove Duplicates from Sorted List

class Solution:
    # @param head, a ListNode
    # @return a ListNode
    def deleteDuplicates(self, head):
        if not head or not head.next:   return head
        pointer = head
        while pointer is not None and pointer.next is not None:
            if pointer.val == pointer.next.val:
                pointer.next = pointer.next.next
            else:
                pointer = pointer.next
        return head

Delete Node in a Linked List
这一题tricky 的地方是你不能拿到前面的节点,所以就换点要删掉的节点的值,连向下一个.

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

另外有一种很重要的特性是环形,头结点和尾节点相连.这两题都是 CC150的经典题.

Linked List Cycle

class Solution:
    # @param head, a ListNode
    # @return a boolean
    def hasCycle(self, head):
        fast, slow = head, head
        while fast and fast.next:
            slow = slow.next
            fast = fast.next.next
            if slow is fast:    return True
        return False

Linked List Cycle II
这一题主要想明白这个公式是怎么来的,

class Solution:
    # @param head, a ListNode
    # @return a list node
    def detectCycle(self, head):
        fast, slow = head, head
        while fast and fast.next:   # prevent infinite loop
            slow = slow.next
            fast = fast.next.next
            if fast is slow:    break
        # X is length before cycle, Y is length of cycle
        # for slow: total distance is X + nY
        # meet at K point
        # X + K = (m - 2n)Y
        if not fast or not fast.next:   return None     # no cycle
        slow = head
        # move X steps
        while slow is not fast:
            slow = slow.next
            fast = fast.next
        return fast
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,776评论 0 33
  • LeetCode 刷题随手记 - 第一部分 前 256 题(非会员),仅算法题,的吐槽 https://leetc...
    蕾娜漢默阅读 17,941评论 2 36
  • 2. Add Two Numbers 先初始化两个结点,一个用来做head,一个作为指引node不断向下延续的指针...
    Morphiaaa阅读 928评论 0 0
  • Single Linked List 相比较另一个基本的数据结构array,linked list有几个优势:尺寸...
    dol_re_mi阅读 8,218评论 0 3
  • //leetcode中还有花样链表题,这里几个例子,冰山一角 求单链表中结点的个数----时间复杂度O(n)这是最...
    暗黑破坏球嘿哈阅读 1,540评论 0 6