力扣hot100 - 114、二叉树展开为链表

题目:思路一:通过先序遍历将元素放到一个数组中,再去遍历数组同时构造一棵二叉树。

代码略

思路二:先递归地把左子树展开为一个链表,再记录一下右子树,左子树移到右子树位置,把记录的右子树放到左子树右节点。

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public void flatten(TreeNode root) {
        if(root == null){
            return;
        }
        flatten(root.left);
        flatten(root.right);
        TreeNode trmp = root.right;
        root.right = root.left;
        root.left = null;
        TreeNode cur = root;
        while(cur != null){
             if( cur.right == null){
                cur.right = trmp;
                break;
            }
            cur = cur.right;
        
        }
        return;
    }
}
相关推荐
承渊政道3 分钟前
【动态规划算法】(似包非包以及卡特兰数问题深入解析)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
fangzt201011 分钟前
从零搭建自动驾驶中间件(四):数据录制与回灌——算法调试的核心基础设施
算法·中间件·自动驾驶
人道领域14 分钟前
【LeetCode刷题日记】二叉树层序遍历完全指南:从基础到LeetCode实战一篇搞定BFS模板,秒杀4道经典面试题
java·开发语言·数据结构·leetcode·面试·二叉树
搬砖的小码农_Sky20 分钟前
比特币区块链:SHA256哈希函数
算法·区块链·哈希算法
承渊政道29 分钟前
【动态规划算法】(一文讲透二维费用的背包问题)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
Zevalin爱灰灰7 小时前
现代密码学 第二章——流密码【下】
算法·密码学
飞Link9 小时前
大模型长文本的“救命稻草”:深度解析 TurboQuant 与 KV Cache 压缩技术
算法
郝学胜-神的一滴9 小时前
深度学习优化核心:梯度下降与网络训练全解析
数据结构·人工智能·python·深度学习·算法·机器学习
Je1lyfish10 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
许彰午10 小时前
03-二叉树——从递归遍历到非递归实现
java·算法