当前位置: 首页 > wzjs >正文

济南建设工程业绩公示的网站市场营销策划方案范文

济南建设工程业绩公示的网站,市场营销策划方案范文,盘古网做网站多少钱,常州网站建设费用题目描述 给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下: 节点的左子树只包含 小于 当前节点的数。节点的右子树只包含 大于 当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。 示例 1&#x…

题目描述

给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。

有效 二叉搜索树定义如下:

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

示例 1:

输入:root = [2,1,3]
输出:true

示例 2:

输入:root = [5,1,4,null,null,3,6]
输出:false
解释:根节点的值是 5 ,但是右子节点的值是 4 。

提示:

  • 树中节点数目范围在[1, 10^4] 内
  • -2^31 <= Node.val <= 2^31 - 1

思路

递归法

可以使用递归法中序遍历将二叉搜索树转变成一个数组,然后只要比较一下,这个数组是否是有序,就能判断是否为搜索二叉树,注意二叉搜索树中不能有重复元素

更好思路是一边遍历一边判断值是不是递增的,此时需要记录前一个节点的值。

递归三部曲:

  1. 确定递归函数的参数和返回值。要定义一个longlong的全局变量,用来比较遍历的节点是否有序,因为后台测试数据中有int最小值,所以定义为longlong的类型,初始化为longlong最小值。
  2. 确定终止条件。遇到空节点就可以终止,空节点也是搜索二叉树。
  3. 确定单层递归的逻辑。中序遍历,一直更新maxVal(相当于前一个节点的值),一旦发现maxVal >= root->val,就返回false,注意元素相同时候也要返回false。

迭代法

可以用迭代法模拟二叉树的中序遍历。

代码

C++版:

递归法

/*** 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:// 递归法,中序遍历long long maxVal = LONG_MIN; // f防止测试数据中有int最小值TreeNode* pre = NULL; // 用来记录前一个节点,这样可以不用初始化最小值bool isValidBST(TreeNode* root) {// 终止条件if (root == NULL) return true;// 递归处理逻辑,中序遍历,验证遍历的元素是不是从小到大bool left = isValidBST(root->left);if (pre != NULL && pre->val >= root->val) return false;pre = root; // 记录前一个节点bool right = isValidBST(root->right);return left && right;}
};

迭代法

/*** 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:// 迭代法,中序遍历bool isValidBST(TreeNode* root) {stack<TreeNode*> st;TreeNode* cur = root;TreeNode* pre = NULL; // 记录前一个节点while (cur != NULL || !st.empty()) {if (cur != NULL) {st.push(cur);cur = cur->left;                // 左} else {cur = st.top();                 // 中st.pop();if (pre != NULL && cur->val <= pre->val)return false;pre = cur; //保存前一个访问的结点cur = cur->right;               // 右}}return true;}
};

Python版:

递归法

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:def __init__(self):self.pre = None  # 用来记录前一个节点def isValidBST(self, root: Optional[TreeNode]) -> bool:if root is None:return Trueleft = self.isValidBST(root.left)if self.pre is not None and self.pre.val >= root.val:return Falseself.pre = root  # 记录前一个节点right = self.isValidBST(root.right)return left and right

迭代法

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:def isValidBST(self, root: Optional[TreeNode]) -> bool:stack = []cur = rootpre = None  # 记录前一个节点while cur is not None or len(stack) > 0:if cur is not None:stack.append(cur)cur = cur.left  # 左else:cur = stack.pop()  # 中if pre is not None and cur.val <= pre.val:return Falsepre = cur  # 保存前一个访问的结点cur = cur.right  # 右return True

需要注意的地方

1.本题所存在的一些陷阱:

陷阱1:先入为主,写出了类似的代码

if (root->val > root->left->val && root->val < root->right->val) {return true;
} else {return false;
}

注意要比较的是左子树所有节点小于中间节点,右子树所有节点大于中间节点。所以以上代码的判断逻辑是错误的。

陷阱2:

样例中最小节点可能是int的最小值,如果这样使用最小的int来比较也是不行的,此时可以初始化比较元素为longlong的最小值。

http://www.dtcms.com/wzjs/217492.html

相关文章:

  • 营业执照网上年审谷歌独立站seo
  • 商业网站建设与维护百度资源搜索引擎
  • 作风建设活动网站知乎关键词排名
  • wordpress建站的利弊南阳本地网络推广优化公司
  • 企业自建站案例全国免费发布广告信息
  • 营销型网站设计的内容广告策划方案怎么做
  • 西安住房和城乡建设局网站开发一款app软件需要多少钱
  • 贵州建设厅网站交换友情链接的方法
  • 洞口做网站推荐营销策划公司排行榜
  • 网站开发行业资讯推广论坛有哪些
  • 网站设计风格的关键词网站注册流程
  • 英国做暧小视频网站培训学校资质办理条件
  • 长春世邦做网站百度新闻首页头条
  • 搭建品牌电商网站怎么做如何自己创建网站
  • 做集群网站网络推广的含义
  • 网站建设 全包东莞优化疫情防控措施
  • .net空网站做九九乘法表网站优化公司上海
  • 网站首页怎么做营销推广的作用
  • 英文 科技网站优化措施最新回应
  • 做网站是哪个专业注册城乡规划师教材
  • 上海阀门网站建设网站制作厂家有哪些
  • 2023新冠第三波疫情症状seo专员工作容易学吗
  • 个体可以做企业网站吗百度贴吧网页入口
  • 怎么上网做网站专业seo站长工具
  • 开发杭州网站优化培训
  • 做网站php java优化网站排名公司
  • 大型网购网站开发框架其中包括
  • 国贸行业的网站建设软文广告平台
  • 国内企业网站欣赏网站建设公司是怎么找客户
  • 广西建设监理协会官方网站中国最大网站排名