91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

【算法日常】判斷環形鏈表

發布時間:2020-07-17 14:57:58 來源:網絡 閱讀:231 作者:wx5dcb7577ac572 欄目:編程語言

環形鏈表

題目來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/linked-list-cycle-ii

【算法日常】判斷環形鏈表

目前考慮到兩種解法,但都需要輔助空間, 第一種 O(n) 第二種 O(1)

第一種 借助輔助字典進行判斷

將走過的節點都記錄在字典中,通過查詢字典的key值是否存在來確定是否有環
時間復雜度為 O(n) , 空間復雜度為 O(n)

代碼如下:

# -*- coding: utf-8 -*-
# @Author   : xaohuihui
# @Time     : 19-12-9
# @File     : detect_cycled_ii.py
# Software  : study

"""
環形鏈表ii
"""

class ListNode:
    def __init__(self, x):
        self.x = x
        self.next = None

# Number.1
def has_cycle(head: ListNode) -> ListNode:
    result = None
    if head and head.next:
        set_node = set()
        while head:
            if head in set_node:
                result = head
                break
            set_node.add(head)
            head = head.next
    return result

if __name__ == '__main__':
    # head=[3,2,0,4] pos= 1
    node1 = ListNode(3)
    node2 = ListNode(2)
    node3 = ListNode(0)
    node4 = ListNode(4)

    node1.next = node2
    node2.next = node3
    node3.next = node4
    node4.next = node2

    result_node = has_cycle(node1)
    if result_node:
        start = node1
        i = 0
        while start:
            if result_node == start:
                print(f"tail connects to node index {i}")
                break
            i += 1
            start = start.next
    else:
        print("no cycle")

輸出如下:

tail connects to node index 1

第二種解法 快慢指針

使用快慢指針,快指針每次走兩步,慢指針每次走一步。
如果單鏈表中有環,快慢指針肯定會相遇,如圖a.所示,在相遇后,將快指針指向開始位置,結束第一次循環。
第二次循環,將快指針變為沒次走一步,慢指針每次走一步,如圖b.所示,如果再次相遇,該點就為環點
時間復雜度為 O(n) , 空間復雜度為 O(1)
特別注意: 若環點就在起始節點,第一次快慢指針相遇一定在環點 ,則fast和slow此時都指向起始節點,則第二次循環不必執行,如圖c.所示

圖a.
【算法日常】判斷環形鏈表

圖b.
【算法日常】判斷環形鏈表

圖c.
【算法日常】判斷環形鏈表

代碼如下:

# -*- coding: utf-8 -*-
# @Author   : xaohuihui
# @Time     : 19-12-9
# @File     : detect_cycled_ii.py
# Software  : study

"""
環形鏈表ii
"""

class ListNode:
    def __init__(self, x):
        self.x = x
        self.next = None

# NUmber.2
def has_cycle(head: ListNode) -> ListNode:
    result = None
    if head and head.next:
        fast = slow = head
        while fast and fast.next:
            fast = fast.next.next
            slow = slow.next
            if fast == slow:
                fast = head
                break
        else:
            return result

        while fast != slow:
            fast = fast.next
            slow = slow.next
        result = fast
    return result

if __name__ == '__main__':
    # head=[3,2,0,4] pos= 0
    node1 = ListNode(3)
    node2 = ListNode(2)
    node3 = ListNode(0)
    node4 = ListNode(4)

    node1.next = node2
    node2.next = node3
    node3.next = node4
    node4.next = node1

    result_node = has_cycle(node1)
    if result_node:
        start = node1
        i = 0
        while start:
            if result_node == start:
                print(f"tail connects to node index {i}")
                break
            i += 1
            start = start.next
    else:
        print("no cycle")

輸出結果

tail connects to node index 0

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

外汇| 铁岭市| 攀枝花市| 桂东县| 鄢陵县| 广西| 永平县| 手游| 马公市| 浮山县| 行唐县| 汤原县| 运城市| 门源| 海伦市| 雅安市| 泗洪县| 册亨县| 乌兰察布市| 中江县| 墨江| 正镶白旗| 荆州市| 广南县| 广元市| 南川市| 华坪县| 黄陵县| 西昌市| 新蔡县| 潼关县| 理塘县| 南召县| 云梦县| 安义县| 辉南县| 娱乐| 偃师市| 涟水县| 陇西县| 周口市|