leetcode 二叉树分离(数据结构树如何转化为二叉树)

技术LeetCode如何把二叉搜索树转换为累加树这篇文章主要介绍了LeetCode如何把二叉搜索树转换为累加树,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下

本文主要介绍LeetCode如何将二叉查找树树转化为累积树,具有一定的参考价值。有兴趣的朋友可以参考一下。希望你看完这篇文章后有很多收获。让边肖带你去了解一下。

1.问题的简要描述

给出二叉查找树的根节点,它有不同的节点值。请将其转换为更大和树,以便每个节点的新值等于原始树中大于或等于node.val的值之和。请注意,二叉查找树满足以下约束:节点的左子树只包含键小于该节点键的节点。节点的右子树仅包含键大于该节点的键的节点。左右子树也必须是二分搜索法树。

2 .示例

LeetCode如何把二叉搜索树转换为累加树

输入:[4,1,6,0,2,5,7,null,null,3,null,null,8]输出:[30,36,21,36,35,26,15,null,null,33,null 1]示例3:输入:根=[1,0,2]输出:[3,3,2]示例4:输入:根=[3,2,4,1]输出:[7,9,4,10]提示:树中的节点数介于1和100之间每个节点的值介于0和100之间。树中的所有值都彼此不同。给定的树是二叉查找树。

3、解决思路

写出解决这个问题最基本的思路,先统计二叉树的节点数据,然后根据题目的已知条件进行计算,再进行数据赋值。

4、问题解决程序

导入Java . util . ArrayList;导入Java . util . list;公共类ConvertBSTTest { static list integer list=new ArrayList();公共静态void main(String[]args){ TreeNode t1=new TreeNode(4);TreeNode t2=新的tree node(1);TreeNode t3=新的tree node(6);TreeNode t4=新的tree node(0);TreeNode t5=新的tree node(2);TreeNode t6=新的tree node(5);TreeNode t7=新的tree node(7);TreeNode t8=新的tree node(3);TreeNode t9=新的tree node(8);t1.left=t2t1.right=t3

de>        t2.left = t4;        t2.right = t5;        t3.left = t6;        t3.right = t7;        t5.right = t8;        t7.right = t9;        TreeNode treeNode = convertBST(t1);        System.out.println("treeNode = " + treeNode);

   }
   public static TreeNode convertBST(TreeNode root) {        if (root == null) {            return null;        }        if (list.size() == 0) {            dfs(root);        }        Integer compute = compute(root.val);        root.val = compute;        if (root.left != null) {            convertBST(root.left);        }        if (root.right != null) {            convertBST(root.right);        }
       return root;
   }

   private static Integer compute(Integer val) {        int sum = 0;        for (int num : list) {            if (num > val) {                sum += num;            }        }        sum += val;        return sum;    }
   private static void dfs(TreeNode root) {        if (root == null) {            return;        }        if (root.left != null) {            dfs(root.left);        }        list.add(root.val);        if (root.right != null) {            dfs(root.right);        }    }}

5,题解程序图片版

6LeetCode如何把二叉搜索树转换为累加树

感谢你能够认真阅读完这篇文章,希望小编分享的“LeetCode如何把二叉搜索树转换为累加树”这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/147023.html

(0)

相关推荐

  • java并发容器J.U.C AQS怎么用

    技术java并发容器J.U.C AQS怎么用java并发容器J.U.C AQS怎么用,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Abstr

    攻略 2021年10月21日
  • Python代码里面如何进行设置IP切换头

    技术Python代码里面如何进行设置IP切换头这篇文章给大家分享的是有关Python代码里面如何进行设置IP切换头的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Pythonrequests

    攻略 2021年11月30日
  • 小数数位顺序表,小数数位表中的知识有哪些

    技术小数数位顺序表,小数数位表中的知识有哪些教学内容小数数位顺序表:小数数位表和小数的读写教学目标:1、使学生了解小数的结构、数位顺序,知道小数的组成,加深对小数意义的认识;2、使学生掌握小数的读写方法,能正确地读写一个

    生活 2021年10月29日
  • 战时管制是指,什么叫战时状态战时措施

    技术战时管制是指,什么叫战时状态战时措施它是指当国家安全受到严重威胁时,将军队处于最高级的备战准备,并向全国发布战争动员令的一种战斗紧张形势战时管制是指。交战国之间的敌对状态。一旦进入战争状态,交战国之间的外交关系、经济

    生活 2021年10月29日
  • 服务器删掉的文件怎么恢复(公司服务器上文件被删除怎么恢复)

    技术企业服务器文件被误删除后如何恢复这期内容当中小编将会给大家带来有关企业服务器文件被误删除后如何恢复,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 用ext3grep恢复rm -

    攻略 2021年12月21日
  • 世界三大蒸馏酒,什么酒能超越茅台的一哥地位

    技术世界三大蒸馏酒,什么酒能超越茅台的一哥地位目前不可能,放眼未来五十年都不会有其他品牌的酒超过。曾经年少的我们只要见到大人喝酒,都会远远避开,真不知道这些人,酒那么难喝那么难闻,居然还喝。随着小伙伴们不断长大,都炫耀的

    生活 2021年10月27日