LeetCode 25 K 個一組翻轉鍊錶

2021-10-06 05:27:08 字數 1250 閱讀 1447

給你乙個鍊錶,每 k 個節點一組進行翻轉,請你返回翻轉後的鍊錶。

k 是乙個正整數,它的值小於或等於鍊錶的長度。

如果節點總數不是 k 的整數倍,那麼請將最後剩餘的節點保持原有順序。

示例:給你這個鍊錶:1->2->3->4->5

當 k = 2 時,應當返回: 2->1->4->3->5

當 k = 3 時,應當返回: 3->2->1->4->5

難度是困難題,不過思路好想,就是實現的時候容易寫錯。

我的思路:1.首先是鍊錶翻轉問題,在每組內都找乙個頭結點(第一組new乙個結點作為頭結點,其他組的頭結點就是前面一組的原來鍊錶的第乙個結點)用頭插法進行該組的翻轉。2.其次是分組問題,每k個進行翻轉,不足k個不動。那麼每次新到一組,首先把頭結點的next結點(該組第乙個結點)作為下一組的頭結點。每組第乙個結點是不需要動的,所以直接從第二個結點開始頭插。

3.因為我是從每組第二個開始頭插的,然後也根據實際題目情況,當k等於時候直接返回原鍊錶即可,避免了bug。

/**

* definition for singly-linked list.

* public class listnode

* }*/ public listnode reversekgroup(listnode head, int k)

listnode pre = new listnode(-1);//pre為當前組的頭結點

pre.next = head;

listnode nextpre = pre.next;//下一組的頭結點(原煉表中每組的第乙個結點)

int index = 0;

boolean flag = false;//用來記錄找到最終鍊錶的起始結點

while (listlength >= k)

if(index == k-1 && !flag)

listnode tmpnode = head.next;

head.next = pre.next;

pre.next = head;

nextpre.next = tmpnode;

head = nextpre.next;

index++;

}pre = nextpre;

nextpre = pre.next;

index = 0;

listlength = listlength - k;

}return lengthnode;

}

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...