LeetCode 鍊錶 快慢指標問題

2021-10-23 18:48:43 字數 1670 閱讀 9053

前言

這是關於leetcode上關於雙指標問題的乙個小結

1. 環形鍊錶

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

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

示例 1:

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

輸出:true

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

示例 2:

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

輸出:true

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

示例 3:

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

輸出:false

解釋:鍊錶中沒有環。

思路:我們可以定義兩個指標進行遍歷(乙個指標比較快,走兩步;乙個指標比較慢,走一步),如果我們的鍊錶中存在環,就相當於操場跑圈,跑的快的人一定會在某乙個時刻跟跑的慢的人相遇。而如果是直線跑道(即不存在環),那麼跑的快的人肯定先到達終點。(即遍歷的結果值為null)

**

public

class

solution

//快慢指標

listnode slow = head;

listnode fast = head.next;

while

(fast != null && fast.next != null)

return

false;}

}

2. 鍊錶的中間結點

876.給定乙個帶有頭結點 head 的非空單鏈表,返回鍊錶的中間結點。

如果有兩個中間結點,則返回第二個中間結點。

示例 1:

輸入:[1,2,3,4,5]

輸出:此列表中的結點 3 (序列化形式:[3,4,5])

返回的結點值為 3 。 (測評系統對該結點序列化表述是 [3,4,5])。

注意,我們返回了乙個 listnode 型別的物件 ans,這樣:

ans.val = 3, ans.next.val = 4, ans.next.next.val = 5, 以及 ans.next.next.next = null.

示例 2:

輸入:[1,2,3,4,5,6]

輸出:此列表中的結點 4 (序列化形式:[4,5,6])

由於該列表有兩個中間結點,值分別為 3 和 4,我們返回第二個結點。

思路:

**

class

solution

//這時候有兩種情況(要麼fast==null,要麼是fast.next==null)

if(fast == null)

return slow;

return slow.next;

}}

Leetcode 快慢指標與鍊錶

1.給定乙個鍊錶,判斷鍊錶中是否有環。解釋 鍊錶中有乙個環,其尾部連線到第二個節點。ps 從例子中根本看不出來好嘛。自己理解就ok 經典思想,快慢指標,如果有環存在,快指標總會追上慢指標 python definition for singly linked list.class listnode ...

鍊錶快慢指標

public listnode removenthfromend listnode head,int n 為了找到要刪除的節點的前乙個節點,所以此處讓fast.next null while fast.next null 此時head為倒數第n個節點的前乙個節點。slow.next slow.nex...

LeetCode 環形鍊錶(雜湊表 快慢指標)

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