【力扣】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;
    }
}
相关推荐
打野二师兄6 分钟前
LeetCode经典题解:21、合并两个有序链表
算法·leetcode·链表
前端拿破轮11 分钟前
腾讯面试官:听说你在字节面试用栈实现队列,那怎么用队列实现栈呢?
算法·leetcode·面试
Hao想睡觉40 分钟前
机器学习之逻辑回归和k-means算法(六)
人工智能·算法·机器学习·逻辑回归
pk_xz1234561 小时前
在Intel Mac的PyCharm中设置‘add bin folder to the path‘的解决方案
ide·人工智能·科技·算法·macos·pycharm·机器人
3Katrina2 小时前
动态规划之打家劫舍系列解析
javascript·算法
樽酒ﻬق2 小时前
Prometheus Operator:Kubernetes 监控自动化实践
java·算法·云原生·运维开发
向左转, 向右走ˉ2 小时前
目标检测中的NMS算法详解
pytorch·python·深度学习·算法·目标检测
大白话讲知识2 小时前
代码随想录算法训练营第三十二天|509. 斐波那契数 70. 爬楼梯 746. 使用最小花费爬楼梯
算法
Lecxcy_Kastreain3 小时前
如何快速搓出一个计算器
算法
chaofa用代码打点酱油4 小时前
Gemini 2.5 Pro 是怎么炼成的?-- gemini 2.5 技术报告阅读笔记与思考
算法·llm