二叉树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);
}
};
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/168871.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • shift work什么意思_shift delete什么意思

    shift work什么意思_shift delete什么意思shift后门之管理员的用处『罗斌原创』shift后门,网络/系统管理员如果想用的话,那还是可以的,为什么要用它呢,第一,公司大部分的电脑都没有光驱,有的甚至不支持从U盘启动,当一个员工走了之后,而他的电脑又设置了密码,无从下手激活成功教程密码,除非把它的电脑拆了,把硬盘挂在其他电脑上去激活成功教程。或者重装系统!这样是不是非常麻烦呢?第…

  • Java开发经典实战!java编程培训学校排名

    Java开发经典实战!java编程培训学校排名GC概述垃圾收集(GarbageCollection)通常被称为“GC”,由虚拟机“自动化”完成垃圾回收工作。思考一个问题,既然GC会自动回收,开发人员为什么要学习GC和内存分配呢?为了能够配置上面的参数配置?参数配置又是为了什么?“当需要排查各种内存溢出,内存泄露问题时,当垃圾成为系统达到更高并发量的瓶颈时,我们就需要对GC的自动回收实施必要的监控和调节。”JVM中程序计数器、虚拟机栈、本地方法栈3个区域随线程而生随线程而灭。栈帧随着方法的进入和退出做入栈和出栈操作,实现了自动的内存清理。它们的

  • c++如何将字符串转为数组(将字符串转换为数组)

    1.将字符串转为byte数组stringimgData=”….,…,….,….”;string[]imgArr=imgData.Split(newchar[]{‘,’});byte[]bty=Array.ConvertAll(imgArr,delegate(strings){returnbyte.Parse(s);});2.将byte数组转为字符串主要…

  • 什么是Servlet容器?

    什么是Servlet容器?什么是Servlet容器?

  • 手把手教你获取x信本地数据库(利用Sqlcipher查看)

    手把手教你获取x信本地数据库(利用Sqlcipher查看)最近一直在研究Xposed等一些hook框架,进行学习做一些demo,这次就正好拿x信练练手,学习学习,也可以学习x信手机本地数据库的表结构设计等。好,废话不多说,直接开干。前提是你的电脑已经安装了adb相关程序,如果你本身就是安卓开发者,想必肯定安装了AndroidStudio,那里直接就有adb相关程序。其次,你准备一台已经root过的安卓手机(要安装的有使用过的x信应用,不

    2022年10月22日
  • mavlink协议原理_mavlink协议长度

    mavlink协议原理_mavlink协议长度参考https://cloud.tencent.com/developer/news/48344https://www.cnblogs.com/lovechen/p/5801679.htmlhtt

发表回复

您的电子邮箱地址不会被公开。

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