首页 > 其他分享 >leetcode刷题day17|二叉树Part05(654.最大二叉树、617.合并二叉树、700.二叉搜索树中的搜索、98.验证二叉搜索树)

leetcode刷题day17|二叉树Part05(654.最大二叉树、617.合并二叉树、700.二叉搜索树中的搜索、98.验证二叉搜索树)

时间:2024-09-13 17:53:29浏览次数:3  
标签:TreeNode val root1 二叉 搜索 二叉树 return root 节点

654.最大二叉树

构造树一般采用的是前序遍历,因为先构造中间节点,然后递归构造左子树和右子树。
递归三步曲:
1、传入参数,整数数组,数组的开始和结束,返回树的中间节点。
2、终止条件:开始大于等于结束,即数组为空。
3、递归逻辑:找到最大的元素,记录元素其下标,构建中间节点;递归构造左子树和右子树。

代码如下:

class Solution {
    public TreeNode constructMaximumBinaryTree(int[] nums) {
        return buildTree(nums,0,nums.length);
    }
    public TreeNode buildTree(int[] nums,int start,int end){
        if(start>=end){
            return null;
        }
        int maxIndex=start;
        int maxNum=nums[maxIndex];
        for(int i=start;i<end;i++){
            if(nums[i]>maxNum){
                maxIndex=i;
                maxNum=nums[i];
            }
        }
        TreeNode root=new TreeNode(maxNum);
        root.left=buildTree(nums,start,maxIndex);
        root.right=buildTree(nums,maxIndex+1,end);
        return root;
    }
}

注意:递归函数中一定要使用受约束的start和end,不要随意写,不然容易出错。

617.合并二叉树

递归三部曲:
1、传入参数:两个树的中间节点root1和root2,返回新树的中间节点root;返回值类行为TreeNode;
2、终止条件:如果root1为空,return root2;如果root2为空,返回root1。
3、递归逻辑:两节点的值相加作为新节点的值。可以直接在树1上去构建,递归构建左树,递归构建右树。

代码如下:

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.二叉搜索树中的搜索

二叉搜索树是一个有序树:

  • 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;
  • 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;
  • 它的左、右子树也分别为二叉搜索树

递归

直接选用先序遍历,找到节点之后直接return即可。
递归三部曲:
1、传入参数:根节点、目标值,返回目标节点。直接使用原函数即可。
2、终止条件:节点为空或找到当前节点则返回该节点
3、递归逻辑:如果当前节点的值小于val,搜索右子树;若当前节点的值大于val,搜索左子树。

代码如下:

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

迭代

根据二叉搜索树的特性直接一路循环即可,无需栈或队列进行存储和回溯。

class Solution {
    public TreeNode searchBST(TreeNode root, int val) {
        TreeNode node=root;
        while(node!=null){
            if(node.val==val) return node;
            else if(node.val<val) node=node.right;
            else node=node.left;
        }
        return null;
    }
}

98.验证二叉搜索树

递归三步曲:
1、传入参数:根节点,最小值,最大值。从上往下遍历,一旦不满足则返回false,所以返回值为boolean类型。
2、终止条件:如果是节点为空,返回true;只有在前面都是true的情况下才会遍历到空节点,并传回true。
3、递归逻辑:如果中间节点小于最小值或大于最大值,则返回false;递归调用左子树和右子树,当两个结果都为true时返回。

代码如下:

class Solution {
    public boolean isValidBST(TreeNode root) {
        return validBST(Long.MIN_VALUE,Long.MAX_VALUE,root);
    }
    public boolean validBST(long lower, long upper,TreeNode root){
        if(root==null) return true;
        if(root.val<=lower || root.val>=upper) return false;
        return (validBST(lower,root.val,root.left))&&(validBST(root.val,upper,root.right));
    }
}

标签:TreeNode,val,root1,二叉,搜索,二叉树,return,root,节点
From: https://blog.csdn.net/m0_51007517/article/details/142213441

相关文章

  • 按图搜索的实时性:阿里巴巴拍立淘API返回值的快速响应
    阿里巴巴拍立淘API作为一种基于图像识别技术的搜索服务,其返回值的快速响应是其实时性的重要体现。以下是对阿里巴巴拍立淘API返回值的快速响应的详细解释,并包含代码示例。一、快速响应机制图像识别技术:阿里巴巴拍立淘API利用先进的图像识别技术,能够迅速分析用户上传的图片特征,并与......
  • 【数据结构】第八节:链式二叉树
    个人主页: NiKo数据结构专栏: 数据结构与算法 源码获取:Gitee——数据结构一、二叉树的链式结构typedefintBTDataType;typedefstructBinaryTreeNode{ BTDataTypedata; structBinaryTreeNode*left;//左子树根节点 structBinaryTreeNode*right;//右子......
  • 基于matlab的黄金搜索法【开源/可直接复制粘贴】
    黄金搜索法是一种无须函数导数的数值优化方法。它基于黄金分割比例来选择新的搜索区间,以逐步缩小搜索范围并逼近极值点。在每次迭代中,算法会根据当前搜索区间的长度和黄金分割比例来计算两个新的点,并在这两个点处评估函数值。然后,根据这两个点的函数值比较结果,选择包含更优解(......
  • 掌握CFML:在输出缓冲区中高效搜索字符串的技巧
    掌握CFML:在输出缓冲区中高效搜索字符串的技巧在开发过程中,特别是使用ColdFusionMarkupLanguage(CFML)进行Web开发时,处理大量数据并快速找到特定字符串是一项常见且重要的任务。为了提高程序效率,我们经常需要在输出缓冲区中搜索特定的字符串,并在必要时对其进行处理。本文将分......
  • PbootCMS英文站搜索页包屑中文修改
    通过修改 {pboot:position} 标签的参数,可以轻松地将面包屑中的中文文本修改为英文,并自定义分隔符和分割图标。具体步骤如下:打开模板文件:打开需要修改的模板文件,例如 search.php。找到面包屑标签:找到 {pboot:position} 标签。修改标签参数:修改分隔符:separato......
  • AI基础 L8 Local Search I 局部搜索
    IterativeImprovementAlgorithms•Inmanyoptimizationproblems,thepathtoagoalisirrelevant—thegoalstateitselfisthesolution•Statespace=asetofgoalstates—findonethatsatisfiesconstraints(e.g.,notwoclassesatsametime)—......
  • DAY14 二叉树part04
    找树左下角的值513.找树左下角的值迭代法层序遍历classSolution{publicList<List<Integer>>reList=newArrayList<>();publicintfindBottomLeftValue(TreeNoderoot){check(root);intindex=reList.size()-1;......
  • 代码随想录算法训练营,9月12日 | 513.找树左下角的值,112. 路径总和,106.从中序与后序遍
    513.找树左下角的值题目链接:513.找树左下角的值文档讲解︰代码随想录(programmercarl.com)视频讲解︰找树左下角的值日期:2024-09-12想法:1.迭代:用层序遍历,遍历每层时记录下第一个节点的值,到最后一层就是要求的值;2.递归:根据最大的深度来找目标值。Java代码如下://迭代classSolut......
  • 题解 力扣 LeetCode 105 从前序与中序遍历序列构造二叉树 C/C++
    题目传送门:105.从前序与中序遍历序列构造二叉树-力扣(LeetCode)https://leetcode.cn/problems/construct-binary-tree-from-preorder-and-inorder-traversal/description/每次在中序遍历序列片段中找到前序遍历序列队首,这是该层的根节点该位置左侧是左子树,右侧是右子树再......
  • Java-数据结构-二叉树-基础 (o゚▽゚)o
    文本目录:❄️一、树形结构:  ▶ 1、概念:▶ 2、特殊的概念: ▶ 3、树的表示形式:❄️二、二叉树:  ▶ 1、概念:   ▶2、两种特殊的二叉树:     ➷1)、满二叉树:      ➷ 2)、完全二叉树:  ▶3、二叉树的性质:    ➷ 1)性质一:  ......