二叉树abcdefghij先序遍历_二叉搜索树的查找递归算法

二叉树abcdefghij先序遍历_二叉搜索树的查找递归算法给定一个二叉树,判断其是否是一个有效的二叉搜索树。假设一个二叉搜索树具有如下特征:节点的左子树只包含小于当前节点的数。节点的右子树只包含大于当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。题解深搜/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() :

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

给定一个二叉树,判断其是否是一个有效的二叉搜索树。

假设一个二叉搜索树具有如下特征:

节点的左子树只包含小于当前节点的数。
节点的右子树只包含大于当前节点的数。
所有左子树和右子树自身必须也是二叉搜索树。

在这里插入图片描述
题解
深搜

/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */
class Solution { 
   
public:
    const int INF = 0x3f3f3f3f;
    const int OINF = -0x3f3f3f3f;
    bool dfs(TreeNode * t,int &Min,int &Max){ 
   
        if(t->left == NULL && t->right == NULL){ 
   
            Min = t->val,Max = t->val;
            return true;
        }
        int tlMax = t->val,tlMin = t->val,trMax = t->val,trMin = t->val;
        Min = Max = t->val;
        if(t->left){ 
   
            if(!dfs(t->left,tlMin,tlMax))return false;
            else{ 
   
                if(tlMax >= t->val || tlMin >= t->val)return false;
                Min = min(tlMin,Min);
                Max = max(tlMax,Max);
            }
        }
        if(t->right){ 
   
            if(!dfs(t->right,trMin,trMax))return false;
            else{ 
   
                if(trMax <= t->val || trMin <= t->val)return false;
                Min = min(trMin,Min);
                Max = max(trMax,Max);
            }
        }
        return true;
    }
    bool isValidBST(TreeNode* root) { 
   
        int a = 0,b = 0;
        return dfs(root,a,b);
    }
};
  1. 仍然为深搜
    dfs(root,lower,upper):代表以root为根节点的树是否在lower和upper范围内
/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */
class Solution { 
   
public:
    const long long INF = 0x3f3f3f3f3f3f3f3f;
    bool dfs(TreeNode *root,long long lower,long long upper){ 
   
        if(root->left == NULL && root->right == NULL){ 
   
            if(root->val > lower && root->val < upper)return true;
            else return false;
        }
        if(root->val <= lower || root->val >= upper)return false;
        if(root->left && !dfs(root->left,lower,root->val))return false;
        if(root->right && !dfs(root->right,root->val,upper))return false;

        return true;
    }
    bool isValidBST(TreeNode* root) { 
   
        cout<<INF<<endl;
        return dfs(root,-INF,INF);
    }
};
  1. 中序遍历
/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */
class Solution { 
   
public:
    vector<int>res;
    bool dfs(TreeNode *root){ 
   
        if(root == NULL)return true;
        if(!dfs(root->left))return false;
        res.push_back(root->val);
        if(res.size() >= 2 && res[res.size() - 1] <= res[res.size() - 2])return false;
        if(!dfs(root->right))return false;

        return true;
    }
    bool isValidBST(TreeNode* root) { 
   
        return dfs(root);
    }
};
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168705.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 几百万数据放入内存不会把系统撑爆吗?「建议收藏」

    几百万数据放入内存不会把系统撑爆吗?

    2022年2月13日
    36
  • testlink用例导入导出平台小脚本:Excel和xml相互转换[通俗易懂]

    testlink用例导入导出平台小脚本:Excel和xml相互转换[通俗易懂]目录testlink用例导入导出平台小脚本:Excel和xml相互转换testlink导出xml在导入xml转Excelexcel转xmlExcel格式如下testlink用例导入导出平台小脚本:Excel和xml相互转换公司启用testlink测试用例平台,发现测试用例的导入导出只支持xml,在testlink上写用例又比较麻烦,效率不高,百度了下,改了源文件测试导入导出直接报错,想着还是自己写个小脚本吧。testlink导出xml在导入在testlink平台写几条测试用例后导出,然后观察xm

    2022年8月22日
    4
  • 大数据建模培训Python

    大数据建模培训Python我国的知名人士:“马云”以前在2015年提及互联网技术将要由IT转至DT,什么叫DT,说白了DT便是数据信息加技术性。现如今是个实实在在的互联网时代,互联网大数据围绕了大家的吃穿住行,能够这么说,互联网大数据是现阶段最珍贵的数据信息藏宝。什么叫Python网络爬虫?Python网络爬虫又叫爬虫技术,有关Python网络爬虫,大家必须了解的有:1、Python基本英语的语法2、HTML网页页面的內容抓取(数据收集)3、HTML网页页面的数据信息获取(数据预处理)4、Scrapy架构

    2022年5月31日
    43
  • Windows 2016 服务器安全配置和加固「建议收藏」

    Windows 2016 服务器安全配置和加固「建议收藏」最近一个项目需要使用Windows服务器,选择安装了最新版的Windows2016,上一次使用Windows服务器还是Windows2008系统,发现变化还是挺多的,依次记录下来以备后面查阅。更换Windows更新服务器如果你觉得默认的Windows更新服务器比较慢,或者如果选择了阿里云或腾讯云服务器的话,可以更换Windows服务器。右键开始菜单图标,选择“运行”,然后输入gped…

    2022年6月9日
    312
  • C#正则表达式匹配任意字符[通俗易懂]

    C#正则表达式匹配任意字符[通俗易懂]不得不说正则很强大,尤其在字符串搜索上匹配任意字符,包括汉字,换行符: [\s\S]*.

    2022年7月15日
    32

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号