面试算法-163-两两交换链表中的节点

题目

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

示例 1:

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

输出:2,1,4,3

java 复制代码
class Solution {
    public ListNode swapPairs(ListNode head) {
        if (head == null || head.next == null) {
            return head;
        }
        ListNode dummy = new ListNode(0);
        dummy.next = head;

        ListNode p1 = dummy;
        ListNode p2 = head;
        ListNode p3 = head.next;
        ListNode next = null;
        while (p3 != null) {
            next = p3.next;

            p1.next = p3;
            p3.next = p2;
            p2.next = next;

            p1 = p2;
            p2 = next;
            p3 = p2 == null ? null : p2.next;
        }
        return dummy.next;
    }
}
相关推荐
怕浪猫34 分钟前
Electron 系列文章封面图
算法·架构·前端框架
假如让我当三天老蒯2 小时前
回归基本功!前端的解构赋值、扩展运算符、剩余参数
前端·面试
Lee川2 小时前
Memory 模块深度解析(面试向)
人工智能·面试
徐小夕3 小时前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
通信小呆呆18 小时前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
benben04418 小时前
强化学习之DQN算法族(基于gymnasium开发)
算法
何以解忧,唯有..19 小时前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
JAVA96520 小时前
JAVA面试-JVM篇 03-JVM运行时数据区哪些是线程私有的哪些是共享的
java·jvm·面试
想吃火锅100520 小时前
【leetcode】88.合并两个有序数组js
算法