leetcode-15-[654]最大二叉树[617]合并二叉树[700]二叉搜索树中的搜索[98]验证二叉搜索树

一、[654]最大二叉树

注意:可以与后序中序建树一起写,思想类似

java 复制代码
class Solution {
    public TreeNode constructMaximumBinaryTree(int[] nums) {
        return traversal(nums,0, nums.length);
    }
    TreeNode traversal(int[] nums,int begin,int end){
        //左闭右开
        if(begin>=end){
            return null;
        }
        if(end-begin==1){
            return new TreeNode(nums[begin]);
        }
        int max=nums[begin];
        int index=begin;
        for(int i=begin;i<end;i++){
            if(nums[i]>max){
                max=nums[i];
                index=i;
            }
        }
        TreeNode root=new TreeNode(max);
        root.left=traversal(nums,begin,index);
        root.right=traversal(nums,index+1,end);
        return root;
    }
}

二、[617]合并二叉树

注意:也可以新建树来存储节点

java 复制代码
class Solution {
    public TreeNode mergeTrees(TreeNode root1, TreeNode root2) {
        if(root1==null){
            return root2;
        }
        if(root2==null){
            return root1;
        }
        root1.val= root1.val+ root2.val;
        root1.left=mergeTrees(root1.left,root2.left);
        root1.right=mergeTrees(root1.right,root2.right);
        return root1;
    }
}

三、[700]二叉搜索树中的搜索

重点;利用二叉搜索树的特性

本题解法多样。

java 复制代码
class Solution {
    public TreeNode searchBST(TreeNode root, int val) {
        if(root==null||root.val==val){
            return root;
        }
        if(val<root.val){
            return searchBST(root.left,val);
        }else{
            return searchBST(root.right,val);
        }

    }
}

四、[98]验证二叉搜索树

重点:类似于数组的双指针

中序遍历!!!

java 复制代码
class Solution {
    TreeNode pre=null;
    public boolean isValidBST(TreeNode root) {
        if(root==null){
            return true;
        }
        //中序遍历!!!!
        //搜索树一般都为中序遍历
        boolean l = isValidBST(root.left);
        if(pre!=null&&pre.val>=root.val)
        {
            return false;
        }
        pre= root;
        boolean r = isValidBST(root.right);
        return l&&r;
    }
}
相关推荐
lifallen几秒前
深入浅出 Arrays.sort(DualPivotQuicksort):如何结合快排、归并、堆排序和插入排序
java·开发语言·数据结构·算法·排序算法
jingfeng5141 分钟前
数据结构排序
数据结构·算法·排序算法
能工智人小辰27 分钟前
Codeforces Round 509 (Div. 2) C. Coffee Break
c语言·c++·算法
kingmax5421200828 分钟前
CCF GESP202503 Grade4-B4263 [GESP202503 四级] 荒地开垦
数据结构·算法
岁忧33 分钟前
LeetCode 高频 SQL 50 题(基础版)之 【高级字符串函数 / 正则表达式 / 子句】· 上
sql·算法·leetcode
eachin_z1 小时前
力扣刷题(第四十九天)
算法·leetcode·职场和发展
闻缺陷则喜何志丹1 小时前
【强连通分量 缩点 拓扑排序】P3387 【模板】缩点|普及+
c++·算法·拓扑排序·洛谷·强连通分量·缩点
机器学习之心2 小时前
机器学习用于算法交易(Matlab实现)
算法·机器学习·matlab
AL流云。2 小时前
【优选算法】C++滑动窗口
数据结构·c++·算法
qq_429879673 小时前
省略号和可变参数模板
开发语言·c++·算法