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;
    }
    
}
相关推荐
普宁彭于晏几秒前
CSS3相关知识点
前端·css·笔记·学习·css3
weixin_436525073 分钟前
Spring Boot 实现流式响应(兼容 2.7.x)
java·spring boot·后端
天涯学馆7 分钟前
从 REST 到 GraphQL:重塑 API 设计的未来
前端·javascript·面试
源码超级联盟9 分钟前
分享一个空指针的bug
java·后端
weixin_4293260917 分钟前
Spring Boot-面试题(52)
java·spring boot·后端
谢尔登23 分钟前
【React】useId
前端·javascript·react.js
qq_3364117525 分钟前
【笔记】Chrome浏览器的性能调试(performance)工具使用和代码优化
前端·chrome·笔记
NoneCoder36 分钟前
Redux 实践与中间件应用
前端·react.js·中间件·面试
明月看潮生39 分钟前
青少年编程与数学 01-011 系统软件简介 02 UNIX操作系统
服务器·青少年编程·操作系统·unix·系统软件
蓝胖子的多啦A梦44 分钟前
Vue3 (数组push数据报错) 解决Cannot read property ‘push‘ of null报错问题
前端·vue3·push·数组数据