LC24. 两两交换链表中的节点

代码随想录

java 复制代码
class Solution {
    // 举例子:假设两个节点 1 -> 2
    // 那么 head = 1; next = 2; next.next = null
    // 那么swapPairs(next.next),传入的是null,再下一次递归中直接返回null
    // 因此 newNode = null
    // 所以 next.next = head; => 2.next = 1; 2 -> 1
    //      head.next=  newNode; => 1.next = null; 1->null
    // 所以 2->1->null
    // 最终返回 next,即返回 2
    public ListNode swapPairs(ListNode head) {
        
        if(head == null || head.next == null)
            return head;

        ListNode next = head.next;

        ListNode newNode = swapPairs(next.next);


        next.next = head;

        head.next = newNode;

        return next;
    }
    
}
相关推荐
京东零售技术6 分钟前
Taro on Harmony :助力业务高效开发纯血鸿蒙应用
前端·开源
苍煜22 分钟前
MinIO 教程:从入门到Spring Boot集成
java·spring boot·后端·minio
前端大白话23 分钟前
救命!这10个Vue3技巧藏太深了!性能翻倍+摸鱼神器全揭秘
前端·javascript·vue.js
掘金詹姆斯23 分钟前
LangChain4j—持久化聊天记忆 Persistence(五)
java·人工智能
嘻嘻嘻嘻嘻嘻ys25 分钟前
《Vue 3全栈架构实战:Vite工程化、Pinia状态管理与Nuxt 3深度解析》
前端·后端
前端大白话26 分钟前
前端人必看!10个JavaScript“救命”技巧,让你告别加班改Bug
前端·javascript·程序员
敖云岚32 分钟前
【Linux】Centos7 安装 Docker 详细教程
linux·运维·服务器
cg501737 分钟前
Vue回调函数中的this
前端·javascript·vue.js
程序猿大波38 分钟前
基于Java,SpringBoot,Vue,HTML宠物相亲配对婚恋系统设计
java·vue.js·spring boot
前端太佬38 分钟前
从零到一实现扫码登录:一个前端菜鸟的踩坑实录
前端·javascript·架构