天天看點

#yyds幹貨盤點# LeetCode 騰訊精選練習 50 題:環形連結清單

題目:

給你一個連結清單的頭節點 head ,判斷連結清單中是否有環。

如果連結清單中有某個節點,可以通過連續跟蹤 next 指針再次到達,則連結清單中存在環。 為了表示給定連結清單中的環,評測系統内部使用整數 pos 來表示連結清單尾連接配接到連結清單中的位置(索引從 0 開始)。注意:pos 不作為參數進行傳遞 。僅僅是為了辨別連結清單的實際情況。

如果連結清單中存在環 ,則傳回 true 。 否則,傳回 false 。

示例 1:

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

輸出:true

解釋:連結清單中有一個環,其尾部連接配接到第二個節點。

示例 2:

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

輸出:true

解釋:連結清單中有一個環,其尾部連接配接到第一個節點。

示例 3:

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

輸出:false

解釋:連結清單中沒有環。

public class Solution {
    public boolean hasCycle(ListNode head) {
        if (head == null || head.next == null) {
            return false;
        }
        ListNode slow = head;
        ListNode fast = head.next;
        while (slow != fast) {
            if (fast == null || fast.next == null) {
                return false;
            }
            slow = slow.next;
            fast = fast.next.next;
        }
        return true;
    }
}
      

繼續閱讀