【力扣】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;
    }
}
相关推荐
IT猿手19 分钟前
2025最新高维多目标优化:基于城市场景下无人机三维路径规划的导航变量的多目标粒子群优化算法(NMOPSO),MATLAB代码
android·开发语言·算法·机器学习·matlab·无人机
零零时26 分钟前
【STL】4.<list>
开发语言·数据结构·c++·经验分享·笔记·算法·list
y.Ghost29 分钟前
数据结构:广义表( Generalized List)及其实现
c语言·数据结构·算法·广义表·广义表的复制·广义表的长度·广义表的深度
阳光男孩011 小时前
力扣2382. 删除操作后的最大子段和
算法·leetcode
程序员黄同学1 小时前
请谈谈 React 中的虚拟 DOM,如何通过 Diff 算法最小化真实DOM 更新次数?
javascript·算法·react.js
MelonTe1 小时前
Go实现动态开点线段树
算法·golang
五味香2 小时前
C语言学习,希尔排序
android·c语言·开发语言·数据结构·学习·算法·排序算法
llllliznc2 小时前
【刷题】贪心算法
算法·贪心算法
波音彬要多做3 小时前
49 set与map的模拟实现
开发语言·数据结构·c++·学习·算法
滨HI04 小时前
P8605 [蓝桥杯 2013 国 AC] 网络寻路
c++·算法·职场和发展·蓝桥杯