问题描述
给定一个链表和一个正整数 k(k 的值小于链表的长度),要求将链表进行分组,每组 k 个节点,在每组中将链表进行倒序,如果最后一组没有 k 个节点,则不用进行逆序,最后将这些分组按顺序连接成新的链表并返回头节点。要求空间复杂度是 O(1)
,并且不能改变链表节点中的值。题目链接:**点我**
样例输入输出
输入:1->2->3->4->5->6->7->8 k = 3
输出:3->2->1->6->5->4->7->8
输入:1->2->3->4->5->6->7->8 k = 1
输出:1->2->3->4->5->6->7->8
问题解法
此题是链表的基本操作。只需要将链表进行分组,在每组中将链表进行倒序即可。需要注意的是保持链表的连续性,即多个倒序后的分组需要能够连接起来成一个新的链表。代码如下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
class Solution { public ListNode reverseKGroup(ListNode head, int k) { ListNode p = head; int length = 0; while (p != null) { length++; p = p.next; } ListNode dummy = new ListNode(0); dummy.next = head; ListNode pHead = dummy.next; ListNode prev = dummy; int index = 0; while (index + k <= length) { prev.next = reverseListNode(pHead, k); prev = pHead; pHead = pHead.next; index += k; } return dummy.next; }
private ListNode reverseListNode(ListNode head, int length) { ListNode p = head; int count = 1; while (count < length) { ListNode pNext = p.next; p.next = pNext.next; pNext.next = head; head = pNext; count++; } return head; } }
|