力扣24 两两交换链表中的节点 Java版本

文章目录

题目

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

示例 1:

输入:head = [1,2,3,4]

输出:[2,1,4,3]

示例 2:

输入:head = []

输出:[]

示例 3:

输入:head = [1]

输出:[1]

提示:

链表中节点的数目在范围 [0, 100] 内

0 <= Node.val <= 100

解题方法

在下面代码中详细注释了

Code

java 复制代码
class Solution {
    public ListNode swapPairs(ListNode head) {
        //如果是空链或者只有一个节点,那么直接返回头节点就行
        if (head == null || head.next == null) {
            return head;
        }
        ListNode pre = head;//pre是最初靠前的节点
        ListNode latter = head.next;//latter是最初靠后的节点
        head = latter;//直接让head=latter,因为一会翻转完成之后,第二个节点就会变成头节点
        ListNode temp = null;//防断链,用于之前已经反转好的部分与后边部分的链接
        while (pre != null && pre.next != null) {//只剩一个节点或者不剩节点就停止反转
            //接下来两行是互换位置
            pre.next = latter.next;
            latter.next = pre;

            if (temp != null) {//temp为空则表明是第一次翻转完,前面没有需要链接的部分
                temp.next = latter;
            }
            temp = pre;
            //更新pre和latter
            pre = pre.next;
            if (pre != null) {
                latter = pre.next;
            }
        }
        return head;
    }
}
相关推荐
期待のcode几秒前
Java的单例模式
java·开发语言·单例模式
断春风2 分钟前
从 JDK 8 到 JDK 21:企业级 Java 版本选择的架构思考
java·架构·jdk
h7ml4 分钟前
构建可扩展的企业微信消息推送服务:事件驱动架构在Java中的应用*
java·架构·企业微信
heartbeat..8 分钟前
JavaWeb 核心:HttpServletRequest 请求行、请求头、请求参数完整梳理
java·网络·web·request
叫我莫言鸭29 分钟前
关于word生成报告的POI学习2循环标题内容
java·学习·word
七夜zippoe33 分钟前
Spring与MyBatis整合原理及事务管理
java·spring·mybatis·事务·mapper
yaoxin52112337 分钟前
278. Java Stream API - 限制与跳过操作全解析
java·开发语言·python
短剑重铸之日44 分钟前
《深入解析JVM》第五章:JDK 8之后版本的优化与JDK 25前瞻
java·开发语言·jvm·后端
love530love1 小时前
【探讨】“父级/基环境损坏,子环境全部失效”,如何避免 .venv 受父级 Python 损坏影响?
java·开发语言·人工智能·windows·python·编程·ai编程
java硕哥1 小时前
Spring源码debug方法
java·后端·spring