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

原题链接

难度: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;}
};

相关内容

热门资讯

2025年中国桌游行业市场深度... (转自:华经产业研究院)桌游是针对如卡片游戏、图板游戏、般牌游戏,以及其他在桌边或任何由数名玩家面对...
巴西成立跨部门委员会酝酿对美关... 巴西总统卢拉14日晚宣布成立一个负责经贸谈判与对策的跨部门委员会,研究如何依据经济对等法案具体施策,...
台股收涨0.98% 格隆汇7月15日|台湾加权指数收盘上涨220.97点,涨幅0.98%,报22835.94点。台积电(...
百闻不如一见|青绽釉色 纹载春... 转自:北京日报客户端钴料为墨瓷胎为纸青花纹样以画入瓷在世界级考古发现南海西北陆坡一号沉船出水瓷器中青...
三大航司预计上半年扣非后净利润... (转自:V观财报)三大航司上半年扣非后净利润亏损预计均有所收窄。14日盘后,中国国航公告,经财务部门...
长沙一女顾客劝阻吸烟被怼,投诉... “劝阻吸烟却被服务员赶走……”7月3日,长沙市民关女士(化名)在长沙望城大碗先生吾悦店用餐时,因劝阻...
文班亚马透露肩部静脉血栓已完全... 北京时间7月15日,据法国驻德州圣安东尼奥体育记者Maxime Aubin报道,他在拉斯维加斯夏季联...
乌F-16坠毁,飞行员身亡,俄... 前不久乌空军一架F-16战机在拦截俄军自杀式无人机时坠毁俄媒称这是自特别军事行动开始以来击落的第3架...
分析师称台积电、英特尔、三星电... 格隆汇7月15日丨KeyBanc Capital Markets分析师John Vinh在一份报告中...
港股异动 | 龙光集团(033... 龙光集团(03380)午后涨超17%,截至发稿,涨9.01%,报1.21港元,成交额4.41亿港元。...