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;
    }
    
}
相关推荐
Mike117.1 分钟前
GBase 8a 数据同步实践:从 T+1 同步、实时镜像到一写多读的落地思路
java·服务器·数据库
Nyarlathotep01132 分钟前
LongAdder为什么那么快?
java·后端
不甜情歌6 分钟前
JS 异步:Event-Loop+async/await
前端
程序员库里6 分钟前
AI协同写作应用-TipTap基础功能
前端·javascript·面试
程序员阿峰7 分钟前
【JavaScript面试题-算法与数据结构】手写一个 LRU(最近最少使用)缓存类,支持 `get` 和 `put` 操作,要求时间复杂度 O(1)
前端·javascript·面试
im_AMBER8 分钟前
AJAX vs Fetch API:Promise 与异步 JavaScript 怎么用?
前端·javascript·面试
用户9751470751369 分钟前
关于通过react使用hooks进行数据状态处理
前端
GISer_Jing10 分钟前
React:从SPA到全场景渲染的进化之路
前端·react.js·前端框架
兑生10 分钟前
【灵神题单·贪心】2279. 装满石头的背包的最大数量 | 排序贪心 | Java
java·开发语言
毕设源码-邱学长12 分钟前
【开题答辩全过程】以 列车信息查询系统为例,包含答辩的问题和答案
java