力扣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;
    }
}
相关推荐
蝎子莱莱爱打怪28 分钟前
OpenClaw 从零配置指南:接入飞书 + 常用命令 + 原理图解
java·后端·ai编程
狼爷2 小时前
Go 没有 override?别硬套继承!用接口+嵌入,写更清爽的“覆盖”逻辑
java·go
会员源码网3 小时前
使用`mysql_*`废弃函数(PHP7+完全移除,导致代码无法运行)
后端·算法
木心月转码ing4 小时前
Hot100-Day10-T438T438找到字符串中所有字母异位词
算法
小兔崽子去哪了4 小时前
Java 自动化部署
java·后端
ma_king4 小时前
入门 java 和 数据库
java·数据库·后端
后端AI实验室5 小时前
我用Cursor开发了3个月,整理出这套提效4倍的工作流
java·ai
HelloReader5 小时前
Wi-Fi CSI 感知技术用无线信号“看见“室内的人
算法
颜酱8 小时前
二叉树分解问题思路解题模式
javascript·后端·算法
码路飞9 小时前
GPT-5.3 Instant 终于学会好好说话了,顺手对比了下同天发布的 Gemini 3.1 Flash-Lite
java·javascript