当前位置: 首页 > news >正文

力扣面试150题--K 个一组翻转链表

Day 35

题目描述

在这里插入图片描述

思路

做法:

  1. 找最后一个需要反转的元素
  2. 每个小组内进行反转
  3. 分为三类点
  4. 组内的第一个点,使用before记录这个点,用于其后面的节点指向前一个节点。移动到下一个节点。
  5. 组内不是第一个点也不是最后一个点的其余点,将该节点指向前一个节点,设置该节点为前一个节点,向后移动
  6. 组内最后一个点,先将这个点指向前一个节点,将这一组前的最后一个节点指向它,将该组的第一个元素下一个指向这个节点的下一个。记录本组最后一个元素以及下一组的第一个元素。
  7. 循环到最大的元素结束
/*** 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 fakehead = new ListNode();if(k==1){return head;}else{fakehead.next = head;//空头结点ListNode x=head;int i=1;while(x!=null){x=x.next;i++;}int len=i-1;//统计链表长度int max=(len/k)*k;//最后一个需要倒序的元素x=head;i=1;ListNode before=head;//指向前一个节点ListNode beg=fakehead;//指向上一组的最后一个元素while(i<=max){if(i%k==1){//小组中第一个元素before=x;x=x.next;i++;}else if(i%k!=1&&i%k!=0){//到小组中的元素ListNode xia=x.next;x.next=before;before=x;x=xia;i++;}else{//小组中最后一个元素ListNode xia=x.next;x.next=before;ListNode s=beg.next;beg.next=x;s.next=xia;beg=s;x=xia;i++;}}}return fakehead.next;  }
}
http://www.xdnf.cn/news/194689.html

相关文章:

  • 机器人--激光雷达
  • ESG跨境电商怎么样?esg跨境电商有哪些功用?
  • 阅读MySQL实战45讲第11天
  • uniapp打包apk如何实现版本更新
  • Spring MVC异常处理利器:深入理解HandlerExceptionResolver
  • SpringBoot实现接口防刷的5种高效方案详解
  • C#/.NET/.NET Core技术前沿周刊 | 第 36 期(2025年4.21-4.27)
  • AudioSet 音频中文类别
  • 蚂蚁seo蜘蛛池:提升网站收录的秘密武器
  • Nacos源码—1.Nacos服务注册发现分析二
  • 系统思考提升培训效能
  • 100天精通Python挑战总览 | 零基础到应用实战!
  • 安徽地区安全员A证考试中,哪些知识点是高频考点?
  • mysql8.0版本部署+日志清理+rsync备份策略
  • LLaMA-Factory部署以及大模型的训练(细节+新手向)
  • 基于 Java 的实现前端组装查询语句,后端直接执行查询方案,涵盖前端和后端的设计思路
  • Vue组件开发进阶:从通信原理到DOM异步更新实战
  • 在视图中交互 闪退问题
  • 1. 用户之窗
  • 【阿里云大模型高级工程师ACP习题集】2.6.用插件扩展答疑机器人的能力边界
  • IEC 61850标准协议解读 2.基于Java的MMS实现
  • Python爬虫实战:获取猫yan电影网最新热门电影数据并做分析,为51观影做参考
  • ArcGIS arcpy代码工具——根据属性结构表创建shape图层
  • OpenGL----OpenGL纹理与纹理缓存区
  • ICH CTD中ISS的关键内容与作用
  • ubuntu新增磁盘挂载
  • 如何将现有资源导入到 Terraform 管理?
  • BT131-ASEMI无人机专用功率器件BT131
  • 【更新】LLM Interview (2)
  • [特殊字符] 基于Docker部署Nacos注册中心及微服务注册发现详解(含MySQL持久化配置)