24. 两两交换链表中的节点 -- 力扣 --JAVA

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

 题目

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

解题思路

    1. 排除无法交换的情况,即:当前节点为空或当前节点无下一个节点;
    2. 获取当前节点的下一个节点,让当前节点的下一个节点指向下下个节点;
    3. 下一个节点指向当前节点;

    代码展示

    class Solution {
        public ListNode swapPairs(ListNode head) {
            if(head == null || head.next == null){
                return head;
            }
            ListNode res = head.next;
            head.next = swapPairs(res.next);
            res.next = head;
            return res;
        }
    }

    image.gif


    目录
    相关文章
    |
    1月前
    |
    分布式计算 Java MaxCompute
    ODPS MR节点跑graph连通分量计算代码报错java heap space如何解决
    任务启动命令:jar -resources odps-graph-connect-family-2.0-SNAPSHOT.jar -classpath ./odps-graph-connect-family-2.0-SNAPSHOT.jar ConnectFamily 若是设置参数该如何设置
    |
    2月前
    |
    存储 安全 Java
    【用Java学习数据结构系列】探索顺序表和链表的无尽秘密(附带练习唔)pro
    【用Java学习数据结构系列】探索顺序表和链表的无尽秘密(附带练习唔)pro
    28 3
    |
    2月前
    |
    分布式计算 资源调度 Hadoop
    大数据-01-基础环境搭建 超详细 Hadoop Java 环境变量 3节点云服务器 2C4G XML 集群配置 HDFS Yarn MapRedece
    大数据-01-基础环境搭建 超详细 Hadoop Java 环境变量 3节点云服务器 2C4G XML 集群配置 HDFS Yarn MapRedece
    96 4
    |
    2月前
    LeetCode第二十四题(两两交换链表中的节点)
    这篇文章介绍了LeetCode第24题的解法,即如何通过使用三个指针(preNode, curNode, curNextNode)来两两交换链表中的节点,并提供了详细的代码实现。
    29 0
    LeetCode第二十四题(两两交换链表中的节点)
    |
    2月前
    Leetcode第十九题(删除链表的倒数第N个节点)
    LeetCode第19题要求删除链表的倒数第N个节点,可以通过快慢指针法在一次遍历中实现。
    47 0
    Leetcode第十九题(删除链表的倒数第N个节点)
    |
    2月前
    |
    分布式计算 Java Hadoop
    Hadoop-30 ZooKeeper集群 JavaAPI 客户端 POM Java操作ZK 监听节点 监听数据变化 创建节点 删除节点
    Hadoop-30 ZooKeeper集群 JavaAPI 客户端 POM Java操作ZK 监听节点 监听数据变化 创建节点 删除节点
    76 1
    05_删除链表的倒数第N个节点
    05_删除链表的倒数第N个节点
    |
    2月前
    (剑指offer)18、删除链表的节点—22、链表中倒数第K个节点—25、合并两个排序的链表—52、两个链表的第一个公共节点(2021.12.07)
    (剑指offer)18、删除链表的节点—22、链表中倒数第K个节点—25、合并两个排序的链表—52、两个链表的第一个公共节点(2021.12.07)
    56 0
    |
    2月前
    【LeetCode 46】450.删除二叉搜索树的节点
    【LeetCode 46】450.删除二叉搜索树的节点
    22 0
    |
    4天前
    |
    Java
    Java—多线程实现生产消费者
    本文介绍了多线程实现生产消费者模式的三个版本。Version1包含四个类:`Producer`(生产者)、`Consumer`(消费者)、`Resource`(公共资源)和`TestMain`(测试类)。通过`synchronized`和`wait/notify`机制控制线程同步,但存在多个生产者或消费者时可能出现多次生产和消费的问题。 Version2将`if`改为`while`,解决了多次生产和消费的问题,但仍可能因`notify()`随机唤醒线程而导致死锁。因此,引入了`notifyAll()`来唤醒所有等待线程,但这会带来性能问题。
    Java—多线程实现生产消费者