面试算法-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;
    }
}
相关推荐
AI工程架构师6 分钟前
通常说算力是多少 FLOPS,怎么理解,GPU和CPU为什么差异这么大
算法
Wect19 分钟前
JSX & ReactElement 核心解析
前端·react.js·面试
祈安_37 分钟前
Java实现循环队列、栈实现队列、队列实现栈
java·数据结构·算法
归去_来兮14 小时前
拉格朗日插值算法原理及简单示例
算法·数据分析·拉格朗日插值
Lee川16 小时前
JavaScript 面向对象编程全景指南:从原始字面量到原型链的终极进化
javascript·面试
千寻girling20 小时前
一份不可多得的 《 Django 》 零基础入门教程
后端·python·面试
SuperEugene20 小时前
Vue生态精选篇:Element Plus 的“企业后台常用组件”用法扫盲
前端·vue.js·面试
千寻girling20 小时前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法
Neptune120 小时前
JavaScript回归基本功之---类型判断--typeof篇
前端·javascript·面试
颜酱1 天前
一步步实现字符串计算器:从「转整数」到「带括号与优化」
javascript·后端·算法