【力扣】24. 两两交换链表中的节点 <栈>

【力扣】24. 两两交换链表中的节点

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

示例 1

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

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

示例 2

输入:head = []

输出:[]

示例 3

输入:head = [1]

输出:[1]

提示

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

0 <= Node.val <= 100

题解

利用 stack,每次取出两个节点放入 stack 中,再从 stack 中拿出两个节点,再把这两个节点串联起来,重复这个逻辑遍历完整个链表,就可以做到两两反转的效果。

java 复制代码
import java.util.*;

class ListNode {
    int val;
    ListNode next;
    ListNode() {}
    ListNode(int val) { this.val = val; }
    ListNode(int val, ListNode next) { this.val = val;this.next = next; }
}

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

        //用来指向新链表 dummyNode
        ListNode dummyNode = new ListNode(-1);
        ListNode prev = dummyNode;
        //用来入栈 出栈,走俩步
        ListNode cur = head;

        //用stack保存每次迭代的两个节点
        Stack<ListNode> stack = new Stack<>();

        while (cur != null && cur.next != null) {
            //将两个节点放入stack中
            stack.add(cur);
            stack.add(cur.next);
            //当前节点往前走两步
            cur = cur.next.next;

            //从stack中弹出两个节点,然后用 prev节点指向新弹出的两个节点
            //弹第一个
            prev.next = stack.pop();
            prev = prev.next;
            //弹第二个
            prev.next = stack.pop();
            prev = prev.next;
        }

/*
        //注意边界条件,当链表长度是奇数时,cur就不为空
        if (cur != null) {
            prev.next = cur;
        }
        else {
            prev.next = null;
        }
*/
		//不管cur是否为空都可以让prev.next指向cur。
    	prev.next = cur;

        return dummyNode.next;
    }
}
相关推荐
老赵聊算法、大模型备案1 小时前
北京市生成式人工智能服务已备案信息公告(2025年12月11日)
人工智能·算法·安全·aigc
CoderYanger2 小时前
C.滑动窗口-求子数组个数-越长越合法——2799. 统计完全子数组的数目
java·c语言·开发语言·数据结构·算法·leetcode·职场和发展
厕所博士2 小时前
红黑树原理前置理解—— 2-3 树
算法·2-3树·红黑树原理理解前置
萌>__<新3 小时前
力扣打卡每日一题————除自身外所有元素的乘积
数据结构·算法
xu_yule4 小时前
算法基础—搜索(2)【记忆化搜索+BFS+01BFS+Floodfill]
数据结构·算法
s09071364 小时前
Xilinx FPGA使用 FIR IP 核做匹配滤波时如何减少DSP使用量
算法·fpga开发·xilinx·ip core·fir滤波
老马啸西风4 小时前
成熟企业级技术平台-10-跳板机 / 堡垒机(Bastion Host)详解
人工智能·深度学习·算法·职场和发展
子夜江寒4 小时前
逻辑回归简介
算法·机器学习·逻辑回归
软件算法开发4 小时前
基于ACO蚁群优化算法的多车辆含时间窗VRPTW问题求解matlab仿真
算法·matlab·aco·vrptw·蚁群优化·多车辆·时间窗
another heaven4 小时前
【软考 磁盘磁道访问时间】总容量等相关案例题型
linux·网络·算法·磁盘·磁道