算法-二叉树展开单链表

这道题我们可以利用栈来做,利用栈先进后出的特性 每次先加入右节点再加入左节点,这样的话弹出的时候正好左节点在前面,右节点在后面满足题目要求。

然后至于是构造单链表,我们可以用一个prev节点 prev的left永远都是null 而prev的right永远都等于cur

因为每次curr都是栈内弹出来的 按照左节点后进先出,所以prev的右节点每次其实都是原来二叉树的左节点,这样的话就能保证满足原二叉树的先序遍历。

代码如下:

java 复制代码
public class flatten {
    class  Solution{
        public void flatten(TreeNode root) {
         // 利用栈来解决 每次从栈内弹出一个节点作为当前访问的节点,获得该节点的子节点,如果子节点不为空,则以此右左节点压入栈内
            if(root == null) return;
            Deque<TreeNode> stack = new LinkedList<TreeNode>();
            stack.push(root);
            TreeNode prev = null;
            while(!stack.isEmpty()) {
                TreeNode curr=stack.pop();
                if(prev != null) {
                    prev.left=null;
                    prev.right=curr;
                }
                TreeNode left=curr.left;
                TreeNode right=curr.right;
                if(right != null) {
                    stack.push(right);
                }
                if(left != null) {
                    stack.push(left);
                }
                prev=curr;
            }


        }
    }
}
相关推荐
じ☆冷颜〃7 小时前
黎曼几何驱动的算法与系统设计:理论、实践与跨领域应用
笔记·python·深度学习·网络协议·算法·机器学习
数据大魔方8 小时前
【期货量化实战】日内动量策略:顺势而为的短线交易法(Python源码)
开发语言·数据库·python·mysql·算法·github·程序员创富
POLITE38 小时前
Leetcode 23. 合并 K 个升序链表 (Day 12)
算法·leetcode·链表
楚来客8 小时前
AI基础概念之八:Transformer算法通俗解析
人工智能·算法·transformer
Echo_NGC22379 小时前
【神经视频编解码NVC】传统神经视频编解码完全指南:从零读懂 AI 视频压缩的基石
人工智能·深度学习·算法·机器学习·视频编解码
会员果汁9 小时前
leetcode-动态规划-买卖股票
算法·leetcode·动态规划
橘颂TA9 小时前
【剑斩OFFER】算法的暴力美学——二进制求和
算法·leetcode·哈希算法·散列表·结构与算法
地平线开发者10 小时前
征程 6 | cgroup sample
算法·自动驾驶
姓蔡小朋友11 小时前
算法-滑动窗口
算法