尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

算法-k个一组翻转链表

算法-k个一组翻转链表
📅 发布时间:2026/6/23 23:01:04

题目

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

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

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

示例 1:

输入:head = [1,2,3,4,5], k = 2输出:[2,1,4,3,5]

题解

思路一

用双向链表解决该问题

/** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode() {} * ListNode(int val) { this.val = val; } * ListNode(int val, ListNode next) { this.val = val; this.next = next; } * } */ class Solution { public ListNode reverseKGroup(ListNode head, int k) { LinkedList<ListNode> link = new LinkedList<ListNode>(); ListNode cur = head; int count = 0; ListNode root = new ListNode(); ListNode r = root; while (cur != null) { while (cur != null && count < k) { ListNode temp = cur.next; cur.next = null; link.add(cur); cur = temp; count++; } while (link.size() > 0) { ListNode node; if(count == k){ node = link.removeLast(); }else { node = link.removeFirst(); } node.next = r.next; r.next = node; r = node; } count = 0; } return root.next; } }

思路二

用双向链表解决该问题,需要使用o(k)的辅助空间,实际上用常量的空间复杂度就可以解决该问题

/** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode() {} * ListNode(int val) { this.val = val; } * ListNode(int val, ListNode next) { this.val = val; this.next = next; } * } */ class Solution { public ListNode reverseKGroup(ListNode head, int k) { ListNode groupHead = new ListNode(); ListNode root = groupHead; ListNode tail = head; ListNode cur = head; int count = 0; while (cur != null) { ListNode temp = cur.next; cur.next = groupHead.next; groupHead.next = cur; cur = temp; count++; if (count == k) { count = 0; //回到尾节点 groupHead = tail; //重新设置下一次的为节点 tail = cur; } } if (count != 0) { cur = groupHead.next; groupHead.next = null; while (cur != null) { ListNode temp = cur.next; cur.next = groupHead.next; groupHead.next = cur; cur = temp; } } return root.next; } }

相关新闻

  • 下班回家还要挑灯检查作业?这款AI作业批改工具,把家长从“修行”中解放了
  • 图像预处理全解|全网独家工况复盘 训练推理预处理对齐、畸变降噪自适应调优、定制流水线搭建、量产避坑指南、助力YOLO检测/OCR识别/工业缺陷/遥感分割全域提准提速
  • 机器学习入门:逻辑回归原理、损失函数与梯度下降推导

最新新闻

  • dset:革命性微型工具库,197B解决JavaScript深层对象赋值难题 [特殊字符]
  • Clock8性能优化:PHP时间操作的最佳实践与性能对比
  • 3分钟掌握PowerToys:微软官方生产力工具箱的深度解析
  • 如何通过构建核心技术项目实现编程技能突破
  • 使用自动化脚本一般可以实现哪些任务?
  • Dorks Eye完整用户指南:从基础搜索到高级技巧的完整教学

日新闻

  • 终极指南:如何用shadPS4在电脑上免费畅玩PS4游戏
  • 打造个性化Instagram Clone:主题定制与用户体验优化技巧
  • 未来展望:RoseTTAFold-All-Atom的发展路线图与社区支持资源汇总

周新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号