LeetCode141 環形鍊錶

2021-09-29 02:12:39 字數 874 閱讀 8532

給定乙個鍊錶,判斷鍊錶中是否有環。

為了表示給定鍊錶中的環,我們使用整數pos來表示鍊錶尾連線到鍊錶中的位置(索引從 0 開始)。 如果pos-1,則在該鍊錶中沒有環。

第一種思路:設定乙個超時時間,在指定時間內一直向後移動指標

指標變為null 說明到達鍊錶尾部,則無環

超時:鍊錶有環

這種思路弊端很明顯,第一超時時間難以界定。第二,耗時

第二種思路:使用set輔助。 向後遍歷鍊錶,每遍歷乙個節點,先判斷是否在集合中,如果不在則放入set 否則則有環,如果知道遍歷結束也沒有重複則無環

時間複雜度o(n),空間複雜度o(n)

public

boolean

hascycle

(listnode head)

else

head = head.next;

}return

false

;}

第三種思路:快慢指標,快指標一次走兩個節點,慢指標一次走乙個節點,如果快指標與慢指標相遇,則有環 如果快指標率先到達鍊錶尾部則無環。

public

boolean

hascycletwo

(listnode head)

listnode fast = head;

listnode slow = head;

while

(slow != fast)

fast = fast.next.next;

slow = slow.next;

}return

true

;}

leetcode141 環形鍊錶

給定乙個鍊錶,判斷鍊錶中是否有環。高階 你能否不使用額外空間解決此題?思路 剛開始想著讓他迴圈下去,直到和頭結點相同的時候,就返回 true,否則就返回 false,但還是 too young too 實際上還是設定兩個指標,乙個快指標和乙個慢指標,只要是在環裡面,總會相遇的,就可 return t...

LeetCode141 環形鍊錶

題目描述 給定乙個鍊錶,判斷鍊錶中是否有環。高階 你能否不使用額外空間解決此題?演算法描述 1.使用兩個快慢指標遍歷鍊錶。slow每次走一步,fast每次走兩步。fast走到鍊錶尾部無環,slow與fast重疊則有環。2.若鍊錶的起始位置等於環的起始位置 slow走一圈回到起始位置,fast剛好走了...

LeetCode141環形鍊錶

給定乙個鍊錶,判斷鍊錶中是否有環。設定兩個指標,乙個fast乙個slow,遍歷整個列表,若達到表尾時仍未出現指標相等則鍊錶無環。c語言版 definition for singly linked list.struct listnode bool hascycle struct listnode h...