61 旋轉鍊錶

2021-09-19 20:43:19 字數 916 閱讀 1095

給定乙個鍊錶,旋轉鍊錶,將鍊錶每個節點向右移動 k 個位置,其中 k 是非負數。

示例 1:

輸入: 1->2->3->4->5->null, k = 2

輸出: 4->5->1->2->3->null

解釋:

向右旋轉 1 步: 5->1->2->3->4->null

向右旋轉 2 步: 4->5->1->2->3->null

示例 2:

輸入: 0->1->2->null, k = 4

輸出: 2->0->1->null

解釋:

向右旋轉 1 步: 2->0->1->null

向右旋轉 2 步: 1->2->0->null

向右旋轉 3 步: 0->1->2->null

向右旋轉 4 步: 2->0->1->null

思路:

先遍歷一遍,得出鍊錶長度len,注意k可能會大於len,因此k%=len。

將尾結點next指標指向首節點,形成乙個環,接著往後跑len-k步,從這裡斷開,就是結果

public listnode rotateright(listnode head, int n)

n = n % length;

if (n == 0)

return head;

//首位相連

cur.next=head;

//這不對 例子1->2 k=1,要換成下面的**

// cur=head;

// while (n-->0)

for (int i=0;i206. 反轉鍊錶 + 234. 回文鍊錶 + 92. 反轉鍊錶 ii

61 旋轉鍊錶

給定乙個鍊錶,旋轉鍊錶,將鍊錶每個節點向右移動 k 個位置,其中 k 是非負數。示例 1 輸入 1 2 3 4 5 null,k 2 輸出 4 5 1 2 3 null 解釋 向右旋轉 1 步 5 1 2 3 4 null 向右旋轉 2 步 4 5 1 2 3 null 示例 2 輸入 0 1 2 ...

61,旋轉鍊錶

給定乙個鍊錶,旋轉鍊錶,將鍊錶每個節點向右移動 k 個位置,其中 k 是非負數。示例 1 輸入 1 2 3 4 5 null,k 2輸出 4 5 1 2 3 null解釋 向右旋轉 1 步 5 1 2 3 4 null 向右旋轉 2 步 4 5 1 2 3 null示例 2 輸入 0 1 2 nul...

61 旋轉鍊錶

雙指標 計算鍊錶長度 count,將k設定為 k count,防止重複旋轉 i指向head j指向與head距離為k的節點 i j 同時向後遍歷 直到 j 指向尾節點 旋轉 definition for singly linked list.class listnode def init self,...