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

【408DS算法题】033基础-判断二叉树是否是二叉排序树

Index

    • 题目
    • 分析实现
    • 总结

题目

给定二叉树的根节点root,判断该二叉树是否是二叉排序树。


分析实现

二叉排序树(BST/二叉搜索树):对于每个节点,其左子树中所有节点的值都小于当前结点的值,其右子树中所有节点的值都大于当前结点的值;左子树和右子树本身也是二叉搜索树。

在二叉排序树的定义中含有着递归的思想 - “左子树和右子树本身也是二叉搜索树”,因此可以使用递归函数来尝试实现。

具体实现如下:

// 判断BST工具函数
bool isBSTUtil(BTNode* cur, int min, int max){if(cur==NULL)return true;if(cur->val<min || cur->val>max) return false;return isBSTUtil(cur->left, min, cur->val) && isBSTUtil(cur->right, cur->val, max);
}// 判断二叉搜索树
bool isBST(BTNode *root){return isBSTUtil(root, INT_MIN, INT_MAX);
}

总结

以上就是利用先序遍历判断二叉排序树的实现,同理也可以利用中序遍历实现判断BST的工具函数(欢迎在评论区讨论交流!)。

特别注意的是,本题有一个常见的错误思路,就是依次判断每个结点:

bool isBST(BTNode *root){if(root==nullptr) return true;if(root->left && root->left->val>=root->val)return false;if(root->right && root->right->val<=root->val)return false;return isBST(root->left) && isBST(root->right);
}

此思路对单个结点的判断并没有错误,但BST要求每个顶点的左子树均大于当前结点,这种写法无法达到这一要求。如:
在这里插入图片描述
根据上面的写法该二叉树会被判定为BST,但结点10不满足10 < {15, 6, 20}


http://www.mrgr.cn/news/18023.html

相关文章:

  • 云计算实训40——部署nmt、部署project_exam_system项目
  • 帧中继了解
  • Centos安装node_exporter
  • 【Unity编辑器扩展】SpriteAltas资源一键转换为TMP_SpriteAsset或Sprite图集
  • shell脚本前置基础
  • 【人工智能 | 机器学习】神经网络
  • LeetCode78 子集
  • java05
  • CC工具箱使用指南:【整库计算YSDM】
  • 基于 R 语言的深度学习——简单回归案例
  • 青龙:定时任务管理平台介绍
  • 中断处理流程举例(21)
  • 【R语言】基于Biomod2集成平台探究物种分布区的构建流程(SDMs)(持续更新中。。。。。。)
  • nvm管理node版本解决node版本冲突问题
  • GNU/Linux - 进程关联的控制终端
  • 四款经典的防泄密软件,企业防泄密必备软件
  • Gin框架:获取请求头与设置响应头
  • 一文直接搞懂SpringMVC完整版教程
  • 最大子数组和
  • Pinia 与 Vuex 对比