LeetCode 25. K 个一组翻转链表
创始人
2024-05-26 00:17:08

原题链接

难度:hard\color{red}{hard}hard

题目描述

给你链表的头节点 headheadhead , kkk 个节点一组进行翻转,请你返回修改后的链表。

kkk 是一个正整数,它的值小于或等于链表的长度。如果节点总数不是 kkk 的整数倍,那么请将最后剩余的节点保持原有顺序。

你不能只是单纯的改变节点内部的值,而是需要实际进行节点交换。

示例 1:

输入:head = [1,2,3,4,5], k = 2
输出:[2,1,4,3,5]
复制示例输入

示例 2:

输入:head = [1,2,3,4,5], k = 3
输出:[3,2,1,4,5]
复制示例输入

提示:

  • 链表中的节点数目为 nnn
  • 1<=k<=n<=50001 <= k <= n <= 50001<=k<=n<=5000
  • 0<=Node.val<=10000 <= Node.val <= 10000<=Node.val<=1000

进阶: 你可以设计一个只用 O(1)O(1)O(1) 额外内存空间的算法解决此问题吗?


算法

(模拟)

  1. 增加虚拟头结点 dummy
  2. 对于每一轮的修改,求出 end 指针为下一轮需要交换的最后一个结点;在找 end 的过程中,若不足 k 个结点,则直接终止循环。
  3. 在找到 end 后,设置 ab 两个指针修改相邻结点之间的连接关系,需要一个临时的 c 指针来指向 bnext。(参考代码)
  4. 最终修改 p->nextc->next
  5. p 指向下一轮修改的起始位置的前一个位置。

在这里插入图片描述

C++ 代码

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode() : val(0), next(nullptr) {}*     ListNode(int x) : val(x), next(nullptr) {}*     ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:ListNode* reverseKGroup(ListNode* head, int k) {ListNode* dummy = new ListNode(0, head);for (auto p = dummy;;) {auto end = p;for (int i = 0; i < k && end != NULL; i ++) end = end->next;if (end == NULL) break;auto a = p->next, b = a->next;for (int i = 0; i < k - 1; i ++) {auto c = b->next;b->next = a;a = b, b = c;}auto c = p->next;p->next = a, c->next = b;p = c;}return dummy->next;}
};

相关内容

热门资讯

工银瑞信基金:梅迎春新任公司副... (来源:北京商报)北京商报讯(记者 刘宇阳)3月10日,工银瑞信基金发布高级管理人员变更公告。公告显...
瞄准汽车电子与机器人  国产封... 3月10日,长电科技(600584)面向汽车电子与机器人应用的芯片封测工厂正式启用,标志着国产芯片封...
久立特材:国际局势动荡及全球油... (来源:财闻) 公司将持续密切关注国际地缘政治形势与油气行业市场动态。 ...
以军称摧毁伊朗西部一处导弹发射... 格隆汇3月10日|据央视,以色列国防军10日发布消息称,以色列空军9日在伊朗西部发现了在伊朗弹道导弹...
永清环保(300187.SZ)... 格隆汇3月10日丨永清环保(300187.SZ)公布,公司近日收到持股5%以上股东金辉盛和出具的《关...