力扣labuladong——一刷day16

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • [一、力扣25. K 个一组翻转链表](#一、力扣25. K 个一组翻转链表)

前言

·递归反转K个一组链表,先定义一个局部反转的函数,用于反转K个一组的部分,返回值是K个一组反转后的头结点,主函数的要接收自己的返回结果,用于连接反转后的链表,返回结果又两种,一种是结尾处不足K个没反转,直接返回当前K个部分的头结点,另外一种是返回当前k个部分的反转的头结点·


一、力扣25. K 个一组翻转链表

递归

java 复制代码
/**
 * 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) {
        if(head == null){
            return head;
        }
        ListNode a = head,b = head;
        for(int i = 0; i < k; i ++){
            if(b == null){
                return head;
            }
            b = b.next;
        }
        ListNode pre = reverse(head,b);
        head.next = reverseKGroup(b,k);
        return pre;
    }
    public ListNode reverse(ListNode head, ListNode b){
        ListNode pre = null, cur = head, net = head;
        while(cur != b){
            net = cur.next;
            cur.next = pre;
            pre = cur;
            cur = net;
        }
        return pre;
    }
}
相关推荐
std7879几秒前
VITA STANDARDS LIST,VITA 最新标准清单大全下载_ansi vita 2025
java·前端·javascript
迢迢星万里灬16 分钟前
Java求职者面试指南:Spring、Spring Boot、MyBatis框架与计算机基础问题解析
java·spring boot·spring·mybatis·计算机基础·面试指南
烟沙九洲19 分钟前
@Transactional 什么情况下会失效
java·spring
会飞的哈士奇31 分钟前
Html实现图片上传/裁剪/马赛克/压缩/旋转/缩放
java·spring·html
穗余42 分钟前
WEB3全栈开发——面试专业技能点P5中间件
中间件·面试·职场和发展
摘星编程1 小时前
原型模式深度解析:Java设计模式实战指南与克隆机制优化实践
java·设计模式·性能优化·原型模式·创建型模式·软件架构·对象克隆
liujing102329291 小时前
Day09_刷题niuke20250609
java·c++·算法
无奈何杨1 小时前
事件时间驱动的策略版本管理:风控系统中的关键设计抉择
java·后端·架构
不7夜宵1 小时前
力扣热题100 k个一组反转链表题解
算法·leetcode·链表
程序员JerrySUN1 小时前
Linux 内核内存管理子系统全面解析与体系构建
java·linux·运维