链表中的节点每k个一组翻转
Posted zhaozihang
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了链表中的节点每k个一组翻转相关的知识,希望对你有一定的参考价值。
class Solution public ListNode reverseKGroup(ListNode head, int k) ListNode dummy = new ListNode(0); // 定义虚拟节点 dummy.next = head; ListNode prev = dummy; // 定义一个前置节点prev,用于保存已经翻转完成的部分的尾部节点 while (head != null) // 遍历整个链表 ListNode tail = prev; for (int i = 0; i < k; i++) // 找到需要翻转的一组k个节点的头和尾 tail = tail.next; if (tail == null) return dummy.next; // 如果剩余节点数不足一组k个节点,则直接返回结果 ListNode next = tail.next; // 保存下一组k个节点的头节点 ListNode[] reversed = reverse(head, tail); // 翻转当前组k个节点 head = reversed[0]; // 更新翻转后的头节点 tail = reversed[1]; // 更新翻转后的尾节点 prev.next = head; // 将翻转后的一组k个节点连接到已经翻转完成的部分的尾部 tail.next = next; // 将翻转后的一组k个节点连接到下一组k个节点的头部 prev = tail; // 更新前置节点prev head = tail.next; // 更新头节点 return dummy.next; // 返回结果 private ListNode[] reverse(ListNode head, ListNode tail) ListNode prev = tail.next; // 定义一个前置节点prev,用于保存已经翻转完成的部分的尾部节点 ListNode curr = head; // 定义一个当前节点curr,用于保存当前遍历到的节点 while (prev != tail) // 翻转当前一组k个节点 ListNode next = curr.next; // 保存下一个节点 curr.next = prev; // 将当前节点的next指针指向前置节点 prev = curr; // 更新前置节点prev curr = next; // 更新当前节点curr return new ListNode[]tail, head; // 返回翻转后的头节点和尾节点
牛客Top200---链表中的节点每k个一组翻转(java通俗易懂详解)
题目
该题目就是反转链表的变形,加一个递归让其递归反转即可
import java.util.*;
public class Solution {
public ListNode reverseKGroup (ListNode head, int k) {
ListNode end = head;
for (int i = 0; i < k; i++) {//找到翻转部分尾节点的下一个节点
if (end == null) {
return head;//跳出条件,不够k个就跳出
}
end = end.next;
}
//反转链表变形,cur!=null变为cur!=end
ListNode pre = null, cur = head;
while(cur != end) {
ListNode next = cur.next;//next记录cur下一个节点
cur.next = pre;
pre = cur;
cur = next;
}
head.next = reverseKGroup(end, k);//尾节点指向下一个翻转的头节点,递归
return pre;
}
}
详细解析
下图带你一步一步理解上面代码
这里递归要搞清楚,代码比较短,简单,但是递归一般在逻辑上会难一点,一定要自己跟着一起理清楚,解改题关键可以想到反转链表,并且通过递归实现逐个翻转
以上是关于链表中的节点每k个一组翻转的主要内容,如果未能解决你的问题,请参考以下文章
#yyds干货盘点# 面试必刷TOP101:链表中的节点每k个一组翻转
链表中的节点每K个一组翻转(NC50/考察次数Top12/难度中等)