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

企业宣传网站建设需求说明书的模板优化大师手机版下载

企业宣传网站建设需求说明书的模板,优化大师手机版下载,福州营销型网站建设,海南住房建设厅网站题目描述 实现一个函数,检查一棵二叉树是否为二叉搜索树。 示例 1: 输入: 2/ \1 3输出: true 示例 2: 输入: 5/ \1 4/ \3 6输出: false 解释: 输入为: [5,1,4,null,null,3,6]。 根节点的值为 5 ,但是其右子节点值为 4 。 解题思路与代码 使用…

题目描述

实现一个函数,检查一棵二叉树是否为二叉搜索树。

示例 1:
输入:

    2/ \1   3

输出: true

示例 2:
输入:

    5/ \1   4/ \3   6

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

解题思路与代码

使用额外数据结构 + 中序遍历

这应该是最简单,并且最容易理解的一种做法了。
由二叉搜索树的性质可知,二叉搜索树的左边节点小于中间节点,中间节点小于右边节点。由这一特性我们可以得知,二叉搜索树的中序遍历是一个有序的数组。

我们只需要检查这个数组是否有序,就能判断出这个二叉树是否是二叉搜索树。

具体实现请看代码:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
public:bool isValidBST(TreeNode* root) {vector<int> result;inorderTraversal(root,result);int size = result.size();for(int i = 1; i < size; ++i )if(result[i-1] >= result[i]) return false;return true;}void inorderTraversal(TreeNode* root,vector<int>& vec){if(root == nullptr) return ;inorderTraversal(root->left,vec);vec.push_back(root->val);inorderTraversal(root->right,vec);}
};

在这里插入图片描述

复杂度分析

时间复杂度:O(n),n是这个二叉树的节点数目。我们要遍历这个二叉树的每一个节点。
空间复杂度:O(n),n是这个二叉树的节点数目,我们要将n个元素压入vector中。此外,函数的递归调用会使用一定的系统栈空间,但是由于递归深度不会超过二叉树的高度,所以可以认为空间复杂度也是 O(n) 级别的。

中序遍历不使用额外数据结构

这种做法,就是稍稍的将我刚刚的那种做法升级了一下,我们使用一个前驱指针,去记录中序遍历的前一个节点。那么中序遍历是先遍历左子树然后遍历中间节点,再去遍历右子树的。所以我们只需要一直去判断,这个前驱指针的值是否一种小于中间节点的值就行了。

具体实现请看代码:

class Solution {
public:TreeNode* pre = nullptr;bool isValidBST(TreeNode* root) {if(root == nullptr) return true;if(!isValidBST(root->left)) return false;if(pre != nullptr && pre->val >= root->val) return false;pre = root;if(!isValidBST(root->right)) return false;return true;}
};

注意:这个代码中不太容易想出来的代码在于这一行:if(!isValidBST(root->left)) return false; 我们的递归逻辑是在这个if判断里面的。这个递归就会把我们一直带到左叶子节点。然后再逐层的返回判断。
在这里插入图片描述

复杂度分析:

时间复杂度:O(n),n为节点的个数。不管怎样我们都要遍历这个树中的所有节点。
空间复杂度:O(h),其中 h 是二叉树的高度。最坏情况下(即二叉树退化为链表时),递归调用深度达到 n,此时栈的空间复杂度为 O(n);平均情况下树的高度是 log n,空间复杂度是 O(log n)。

这个代码优化了空间复杂度,因为没有用到额外的数据结构。但是执行代码所需要的时间缺增加了。这是因为我们每次递归都要做许多的判断。而上一次的代码只需要在for循环里做少量判断就行了。

总结

这道题不算太难。只要能及时的想起二叉搜索树的性质,就能轻松解题。

http://www.ritt.cn/news/5544.html

相关文章:

  • 网站建设公司的重要性慧生活798app下载
  • 网站上删除信息如何做动态网站设计
  • 做外贸需要几个网站外链工具xg下载
  • 做网站播放未上映的电影是侵权吗网站外包一般多少钱啊
  • 做网站之前要先购买服务器吗西安百度推广开户运营
  • 网站建设最基础的是什么seo排名课程咨询电话
  • 南通做公司网站长沙关键词自然排名
  • 淘宝的网站怎么做新媒体seo培训
  • wordpress空页面模板培训如何优化网站
  • 自做网站好做吗郑州seo哪家好
  • 华美天一建筑公司网站整站优化包年
  • 网站建设是一次性给钱还是什么自制网站 免费
  • asp网站模板免费下载免费网站站长查询
  • 设置网站首页搜索引擎优化seo公司
  • 怎样做自己的的社交网站竞价排名服务
  • 动漫画设计与制作是学什么成都爱站网seo站长查询工具
  • 东莞建站网站模板数据分析方法
  • 网站的做代理商西安新站网站推广优化
  • 网站建设业务前景百度指数在线查询前100
  • 网站过期原因百度搜索推广开户
  • 南昌网站全新开发企业查询网站
  • 自己如何做企业网站如何建网站
  • wordpress纯静态seo工具在线访问
  • 广州市哪有做网站的网络服务器
  • 网站开发不用mvc行不行衡阳网站建设公司
  • 尚义网站建设怎么提高百度搜索排名
  • 福田网站设计方案朋友圈的广告推广怎么弄
  • 电子商务网站建设的总体设计百度seo关键词优化费用
  • 网站建设 长安镇seo搜索排名影响因素主要有
  • 网站建设及优化的策划书百度店铺免费入驻