当前位置: 首页 > article >正文

LeetCode Hot100 114.二叉树展开为链表

题目

给你二叉树的根结点 root ,请你将它展开为一个单链表:

  • 展开后的单链表应该同样使用 TreeNode ,其中 right 子指针指向链表中下一个结点,而左子指针始终为 null 。
  • 展开后的单链表应该与二叉树 先序遍历 顺序相同。

方法一:先前序遍历,然后再修改左右指针

class Solution {
    public void flatten(TreeNode root) {
        List<TreeNode> list = new ArrayList<TreeNode>();
        preorderTraversal(root, list);
        int size = list.size();
        for(int i = 1; i < size; i++) {
            TreeNode pre = list.get(i - 1), cur = list.get(i);
            pre.right = cur;
            pre.left = null;
        }
    }
    private void preorderTraversal(TreeNode root, List<TreeNode> list) {
        if (root == null)
            return;
        list.add(root);
        preorderTraversal(root.left, list);
        preorderTraversal(root.right, list);
    }
}

方法二:寻找前驱节点

class Solution {
    public void flatten(TreeNode root) {
        TreeNode curr = root;
        while (curr != null) {
            if (curr.left != null) {
                TreeNode next = curr.left;
                TreeNode predecessor = next;
                while (predecessor.right != null) {
                    predecessor = predecessor.right;
                }
                predecessor.right = curr.right;
                curr.left = null;
                curr.right = next;
            }
            curr = curr.right;
        }
    }
}


http://www.kler.cn/a/147549.html

相关文章:

  • MongoDB自定义顺序排序
  • T265相机双目鱼眼+imu联合标定(全记录)
  • jenkins用户在执行scp的时候如何做免密登录
  • 系统架构师考试18天极限备考复盘(2024年11月)
  • @Autowired和@Resource的区别
  • java-Day06 内部类 Lambda表达式 API
  • 企业网络中的身份安全
  • Redis与Mysql的数据强一致性方案
  • C语言——猜凶手
  • 2023_Spark_实验二十二:Zookeeper的集群安装
  • 中英双语大模型ChatGLM论文阅读笔记
  • MySQL远程连接数据库
  • 涵盖多种功能,龙讯旷腾Module第一期:物质结构
  • Win10电脑用U盘重装系统的步骤
  • 传统数仓和clickhouse对比
  • hnust信息安全管理试题
  • Java基础-中级-高级面试题汇(一)
  • 图形编辑器开发:快捷键的管理
  • 五、Lua流程控制与函数
  • Elasticsearch:ES|QL 查询中的元数据字段及多值字段
  • PHP定义的变量 常量 静态变量等储存在内存什么位置?
  • ESP32-Web-Server编程-HTML 基础
  • 适用于iOS 的顶级苹果数据恢复软件
  • 爬虫爬取百度图片、搜狗图片
  • JAVA将PDF转图片
  • java大视频在线预览(支持断点下载)