Class Solution

java.lang.Object
g0101_0200.s0141_linked_list_cycle.Solution

public class Solution extends Object
141 - Linked List Cycle.<p>Easy</p> <p>Given <code>head</code>, the head of a linked list, determine if the linked list has a cycle in it.</p> <p>There is a cycle in a linked list if there is some node in the list that can be reached again by continuously following the <code>next</code> pointer. Internally, <code>pos</code> is used to denote the index of the node that tail&rsquo;s <code>next</code> pointer is connected to. <strong>Note that <code>pos</code> is not passed as a parameter</strong>.</p> <p>Return <code>true</code> <em>if there is a cycle in the linked list</em>. Otherwise, return <code>false</code>.</p> <p><strong>Example 1:</strong></p> <p><img src="https://assets.leetcode.com/uploads/2018/12/07/circularlinkedlist.png" alt="" /></p> <p><strong>Input:</strong> head = [3,2,0,-4], pos = 1</p> <p><strong>Output:</strong> true</p> <p><strong>Explanation:</strong> There is a cycle in the linked list, where the tail connects to the 1st node (0-indexed).</p> <p><strong>Example 2:</strong></p> <p><img src="https://assets.leetcode.com/uploads/2018/12/07/circularlinkedlist_test2.png" alt="" /></p> <p><strong>Input:</strong> head = [1,2], pos = 0</p> <p><strong>Output:</strong> true</p> <p><strong>Explanation:</strong> There is a cycle in the linked list, where the tail connects to the 0th node.</p> <p><strong>Example 3:</strong></p> <p><img src="https://assets.leetcode.com/uploads/2018/12/07/circularlinkedlist_test3.png" alt="" /></p> <p><strong>Input:</strong> head = [1], pos = -1</p> <p><strong>Output:</strong> false</p> <p><strong>Explanation:</strong> There is no cycle in the linked list.</p> <p><strong>Constraints:</strong></p> <ul> <li>The number of the nodes in the list is in the range <code>[0, 10<sup>4</sup>]</code>.</li> <li><code>-10<sup>5</sup> <= Node.val <= 10<sup>5</sup></code></li> <li><code>pos</code> is <code>-1</code> or a <strong>valid index</strong> in the linked-list.</li> </ul> <p><strong>Follow up:</strong> Can you solve it using <code>O(1)</code> (i.e. constant) memory?</p>
  • Constructor Details

    • Solution

      public Solution()
  • Method Details

    • hasCycle

      public boolean hasCycle(ListNode head)