給你乙個鍊錶,每 k 個節點一組進行翻轉,請你返回翻轉後的鍊錶。
k 是乙個正整數,它的值小於或等於鍊錶的長度。
如果節點總數不是 k 的整數倍,那麼請將最後剩餘的節點保持原有順序。鏈結
遞迴,每次翻轉k個節點,當不夠k個節點時直接返回head
class
solution
if(steplistnode dummy=null;
listnode first=head;
while
(first!=tail)
//翻轉後,head變成末尾,與下一層的dummy頭相連
head.next=
reversekgroup
(first,k)
;return dummy;
}}
迭代
class
solution
}//儲存下一段的頭
listnode tailnex=tail.next;
listnode[
]ret=
reverse
(head,tail)
;//上一段頭連線
pre.next=ret[0]
;//賦值翻轉後的尾
tail=ret[1]
;//連線下一段的頭
tail.next=tailnex;
//更新pre
pre=tail;
//下一段翻轉的head
head=tail.next;
}return dummy.next;
}private listnode[
]reverse
(listnode head,listnode tail)
//翻轉後頭尾交換
return
newlistnode
;}}
LeetCode 25 k個一組翻轉鍊錶
給出乙個鍊錶,每 k 個節點一組進行翻轉,並返回翻轉後的鍊錶。k 是乙個正整數,它的值小於或等於鍊錶的長度。如果節點總數不是 k 的整數倍,那麼將最後剩餘節點保持原有順序。給定這個鍊錶 1 2 3 4 5 當 k 2 時,應當返回 2 1 4 3 5 當 k 3 時,應當返回 3 2 1 4 5 這...
LeetCode 25 K個一組翻轉鍊錶
按照每k個為一組,記錄這組內的頭和尾,第一組只需記錄翻轉後的尾即tail 接下來的每一組記錄翻轉後頭 nhead 和尾 ntail.注意更新的順序 class solution length k if length 0 return head p head listnode otail head l...
leetcode 25 k個一組翻轉鍊錶
題目描述 給出乙個鍊錶,每 k 個節點一組進行翻轉,並返回翻轉後的鍊錶。k 是乙個正整數,它的值小於或等於鍊錶的長度。如果節點總數不是 k 的整數倍,那麼將最後剩餘節點保持原有順序。示例 給定這個鍊錶 1 2 3 4 5 當 k 2 時,應當返回 2 1 4 3 5 當 k 3 時,應當返回 3 2...