141 環形鍊錶

2021-10-22 08:38:29 字數 1502 閱讀 4598

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

如果鍊錶中有某個節點,可以通過連續跟蹤 next 指標再次到達,則鍊錶中存在環。 為了表示給定鍊錶中的環,我們使用整數 pos 來表示鍊錶尾連線到鍊錶中的位置(索引從 0 開始)。 如果 pos 是 -1,則在該鍊錶中沒有環。注意:pos 不作為引數進行傳遞,僅僅是為了標識鍊錶的實際情況。

如果鍊錶中存在環,則返回 true 。 否則,返回 false 。

高階:你能用 o(1)(即,常量)記憶體解決此問題嗎?

示例 1:

輸入:head = [3,2,0,-4], pos = 1

輸出:true

解釋:鍊錶中有乙個環,其尾部連線到第二個節點。

示例 2:

輸入:head = [1,2], pos = 0

輸出:true

解釋:鍊錶中有乙個環,其尾部連線到第乙個節點。

示例 3:

輸入:head = [1], pos = -1

輸出:false

解釋:鍊錶中沒有環。

鍊錶中節點的數目範圍是 [0, 104]

-105 <= node.val <= 105

pos 為 -1 或者鍊錶中的乙個 有效索引 。

快慢指標

做題時不了解這個原理,看的解析做出的。

// 建立快慢鍊錶

listnode slow=head;

listnode fast=head.next;

// 外層:快慢鍊錶不相等

// 因此該while迴圈外則快慢鍊錶重合,返回true

while(slow!=fast)

// 否則快慢指標依次遞增

// 遞增到重合,跳出迴圈返回true

// 遞增到快速鍊錶無後續節點,返回falsefalse

slow=slow.next;

fast=fast.next.next;

}

return true;}}

hashset

public class solution 

//新增

set.add(head);

head=head.next;

}return false;}}

其中hashset宣告的型別一定要是listnode,不能是值型別,後續判斷的也不是val,因為可能包含重複值。

但宣告為listnode型別,儲存的就是節點位址值,位址值是不會重複的。

141 環形鍊錶

給定乙個鍊錶,判斷鍊錶中是否有環。高階 你能否不使用額外空間解決此題?乙個快指標走兩步 乙個慢指標走一步 如果相遇就有環 不然沒環 class solution def hascycle self,head type head listnode rtype bool index1 head inde...

141 環形鍊錶

鏈結 給定乙個鍊錶,判斷鍊錶中是否有環。為了表示給定鍊錶中的環,我們使用整數 pos 來表示鍊錶尾連線到鍊錶中的位置 索引從 0 開始 如果 pos 是 1,則在該鍊錶中沒有環。示例1輸入 head 3,2,0,4 pos 1 輸出 true 解釋 鍊錶中有乙個環,其尾部連線到第二個節點。示例2 輸...

141 環形鍊錶

給定乙個鍊錶,判斷鍊錶中是否有環。為了表示給定鍊錶中的環,我們使用整數 pos 來表示鍊錶尾連線到鍊錶中的位置 索引從 0 開始 如果 pos 是 1,則在該鍊錶中沒有環。示例 1 輸入 head 3,2,0,4 pos 1 輸出 true 解釋 鍊錶中有乙個環,其尾部連線到第二個節點。1.首先想到...