【力扣】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;
    }
}
相关推荐
墨染点香2 小时前
LeetCode 刷题【144. 二叉树的前序遍历】
数据结构·算法·leetcode
cynicme7 小时前
力扣3318——计算子数组的 x-sum I(偷懒版)
java·算法·leetcode
im_AMBER10 小时前
算法笔记 09
c语言·数据结构·c++·笔记·学习·算法·排序算法
凯芸呢10 小时前
Java中的数组(续)
java·开发语言·数据结构·算法·青少年编程·排序算法·idea
寂静山林10 小时前
UVa 1030 Image Is Everything
算法
AI柠檬10 小时前
几种排序算法的实现和性能比较
数据结构·算法·c#·排序算法
weixin_4296302611 小时前
第6章 支持向量机
算法·机器学习·支持向量机
SweetCode11 小时前
C++ 实现大数加法
开发语言·c++·算法
王哈哈^_^11 小时前
【数据集】【YOLO】【目标检测】共享单车数据集,共享单车识别数据集 3596 张,YOLO自行车识别算法实战训推教程。
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计
CodeWizard~11 小时前
AtCoder Beginner Contest 430赛后补题
c++·算法·图论