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;}
};

相关内容

热门资讯

是最近的距离,也是最远的距离|...   赵紫名  因为有梅西,阿根廷毫无疑问是本届世界杯最受媒体关注的球队之一,日常训练、赛前新闻发布会...
下周山西多分布不均雷雨天气 局... (来源:山西日报)未来一周,我省多分布不均雷雨天气,局部伴有强对流,主要影响时段为7月4日—8日和1...
警方通报“少年在家和同学饮酒后... (来源:法治日报)7月3日晚,安徽淮南市公安局田家庵分局发布警情通报:关于网上报道“淮南一15岁少年...
中船先锋|七〇三所蒸汽动力事业...   在庆祝中国共产党成立105周年之际,党中央对全国“两优一先”进行表彰。中国船舶集团有限公司七〇三...
啤酒节里藏着“宝藏”文创市集   游客在选购文创产品。  本报讯(记者 李佳琪文/摄)7月3日,第二十四届哈尔滨国际啤酒节在哈尔滨...