LeetCode-25 -两两交换链表中的节点

力扣24题

题目描述:

给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。

**题解思路:**递归,确定递归三部曲的条件:

  1. 确定递归函数的参数和返回值:回交换后子链表的头节点;
  2. 确定递归的终止条件:temp是null或head是null
  3. 确定单层递归的逻辑:temp是head的下一个节点,head后接交换完成的子链表,temp接head;
java 复制代码
class Solution {
    public ListNode swapPairs(ListNode head) {
        if(head==null || head.next==null){
            return head;
        }
        ListNode temp=head.next;
        // 执行递归逻辑
        head.next=swapPairs(temp.next);
        temp.next=head;
        return temp;
    }
}
相关推荐
yashuk3 分钟前
C语言入门教程:程序结构与算法举例
c语言·算法·教程·程序设计·开发过程
zsc_1186 分钟前
pvz3解码小游戏求解算法 (二)
算法
hanbr14 分钟前
每日一题day1(Leetcode 76最小覆盖子串)
算法·leetcode
AI科技星16 分钟前
张祥前统一场论中两个电荷定义的统一性解析
开发语言·线性代数·算法·数学建模·平面
代码地平线16 分钟前
C语言实现堆与堆排序详解:从零手写到TopK算法及时间复杂度证明
c语言·开发语言·算法
小江的记录本17 分钟前
【大语言模型】大语言模型——核心概念(预训练、SFT监督微调、RLHF/RLAIF对齐、Token、Embedding、上下文窗口)
java·人工智能·后端·python·算法·语言模型·自然语言处理
炘爚18 分钟前
LeetCode(两两交换链表中的节点)
算法·leetcode·链表
wsoz18 分钟前
Leetcode矩阵-day7
c++·算法·leetcode·矩阵
念越19 分钟前
算法每日一题 Day01|双指针解决移动零问题
java·算法·力扣
不想看见40420 分钟前
Merge k Sorted Lists 优先队列--力扣101算法题解笔记
笔记·算法·leetcode