题目

给定二叉搜索树(BST)的根节点和一个值。 你需要在BST中找到节点值等于给定值的节点。 返回以该节点为根的子树。 如果节点不存在,则返回 NULL。

例如,

给定二叉搜索树:

        4
/ \
2 7
/ \
1 3 和值: 2

你应该返回如下子树:

      2
/ \
1 3

在上述示例中,如果要找的值是 5,但因为没有节点值为 5,我们应该返回 NULL


Tag


代码

1.递归 (一遍ac)

class Solution {
public:
TreeNode* searchBST(TreeNode* root, int val) {
if(!root)
return nullptr;
return Helper(root,val);
} TreeNode* Helper(TreeNode* root, int val)
{
if(root==nullptr) return root;
if(root->val==val) return root;
else if (root->val>val)
root=Helper(root->left,val);
else if (root->val <val)
root= Helper(root->right,val);
return root;
}
};
class Solution {
public:
TreeNode* searchBST(TreeNode* root, int val) {
if(!root||val==root->val) return root;
if(root->val<val)
root=searchBST(root->right,val);
else if (root->val>val)
root =searchBST(root->left,val);
return root;
}
};

2.迭代

class Solution {
public:
TreeNode* searchBST(TreeNode* root, int val) {
while(root&&root->val!=val)
{
root= (root->val<val)? root->right: root->left;
} return root;
}
};

问题

最新文章

  1. &lt;java基础学习&gt;RE 基础语法
  2. 1.3 迭代器 - iterator
  3. 实现TabView(页签)效果
  4. java开发微信公众平台备忘
  5. poj 1611 The Suspects 解题报告
  6. ExtJs之进度条实现
  7. cf754 A. Lesha and array splitting
  8. NaN属性,isNaN函数
  9. 关于SQL Server 数据库的备份
  10. EntityFramework 和 linq 判断是否在指定时间段内的方法
  11. POJ1664
  12. CSS盒模型和定位的类型
  13. centos 设置删除提示
  14. Day2 - Linux发展史
  15. nyoj 正数性质
  16. VC++调试错误的解决方案
  17. Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields(翻译)
  18. Spring Cloud(Dalston.SR5)--Eureka 常用配置
  19. 【2】C#读取文本文件
  20. 微信小游戏5.2.2 在子项目中使用EUI制作排行榜报错 wx.getFileSystemManager not function

热门文章

  1. (转)使用介质设备安装 AIX 以通过 HMC 安装分区
  2. Eclipse中引来的jar包乱码
  3. 标准I/O库(详解)(Standard I/O Library)
  4. ORACLE 查看表空间
  5. asp.net用zip方法批量导出txt
  6. AOSP 源码下载
  7. Myeclipse与tomcat的运行问题
  8. 算法练习-Palindrome Number
  9. 光标显示样式 css 中 cursor 属性使用
  10. 探讨下在Delphi里面进程之间的数据共享