LeetCode700. Search in a Binary Search Tree
2024-09-27 09:06:53
题目
给定二叉搜索树(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;
}
};
问题
最新文章
- <;java基础学习>;RE 基础语法
- 1.3 迭代器 - iterator
- 实现TabView(页签)效果
- java开发微信公众平台备忘
- poj 1611 The Suspects 解题报告
- ExtJs之进度条实现
- cf754 A. Lesha and array splitting
- NaN属性,isNaN函数
- 关于SQL Server 数据库的备份
- EntityFramework 和 linq 判断是否在指定时间段内的方法
- POJ1664
- CSS盒模型和定位的类型
- centos 设置删除提示
- Day2 - Linux发展史
- nyoj 正数性质
- VC++调试错误的解决方案
- Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields(翻译)
- Spring Cloud(Dalston.SR5)--Eureka 常用配置
- 【2】C#读取文本文件
- 微信小游戏5.2.2 在子项目中使用EUI制作排行榜报错 wx.getFileSystemManager not function