力扣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;
    }
}
相关推荐
北执南念7 分钟前
基于 Spring 的策略模式框架,用于根据不同的类的标识获取对应的处理器实例
java·spring·策略模式
王道长服务器 | 亚马逊云11 分钟前
一个迁移案例:从传统 IDC 到 AWS 的真实对比
java·spring boot·git·云计算·github·dubbo·aws
华仔啊15 分钟前
为什么 keySet() 是 HashMap 遍历的雷区?90% 的人踩过
java·后端
9号达人28 分钟前
Java 13 新特性详解与实践
java·后端·面试
橙序员小站34 分钟前
搞定系统设计题:如何设计一个支付系统?
java·后端·面试
nsjqj35 分钟前
数据结构:优先级队列(堆)
数据结构
嘟嘟可在哪里。1 小时前
IntelliJ IDEA git凭据帮助程序
java·git·intellij-idea
岁忧1 小时前
(LeetCode 每日一题) 3541. 找到频率最高的元音和辅音 (哈希表)
java·c++·算法·leetcode·go·散列表
_extraordinary_1 小时前
Java 多线程进阶(四)-- 锁策略,CAS,synchronized的原理,JUC当中常见的类
java·开发语言
pusue_the_sun1 小时前
每日算法题推送
算法·双指针