leetcode 700 学习笔记(递归,迭代)

700. 二叉搜索树中的搜索

问题描述:传送门

在这里插入图片描述

思路:

关于二叉搜索树,要理清一个概念,它是一个有序树。

  1. 若它左子树不为空,则左子树上所有节点的值均小于它的根节点的值。
  2. 若它右子树不为空,则右子树上所有节点的值均大于它的根节点的值。
  3. 左右子树也是二叉树

1、递归

① 确定递归函数的参数和返回值
参数:传入根节点,以及要搜索的数值。
返回值:以这个搜索数值所在的节点。

代码如下:

TreeNode* searchBST(TreeNode* root, int val)

② 确定终止条件

如果root为空,或者找到这个数值了,就返回root节点。

if (root == NULL || root->val == val) 
	return root;

③ 确定单层递归的逻辑

因为二叉搜索树的节点是有序的,所以可以有方向的去搜索。
如果root->val>val,那根据条件,搜索左子树。
如果root->bal<val,就搜索右子树。
最后,如果都没有搜索到,就返回NULL。
代码如下:

if (root->val > val) 
	return searchBST(root->left, val); 
// 注意这里加了return 
if (root->val < val) 
	return searchBST(root->right, val);
return NULL;

如果搜索一条边,递归函数就需要加返回值。

完整代码如下:

TreeNode* searchBST(TreeNode* root, int val) {
    if (root == NULL || root->val == val) return root;
    if (root->val > val) return searchBST(root->left, val);
    if (root->val < val) return searchBST(root->right, val);
    return NULL;
}

2、迭代法

以查找3为例。
中间节点如果大于3就往左走,如果小于3就往右走。
如下图:
在这里插入图片描述

class Solution {
public:
    TreeNode* searchBST(TreeNode* root, int val) {
        while (root != NULL) {
            if (root->val > val) root = root->left;
            else if (root->val < val) root = root->right;
            else return root;
        }
        return NULL;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

晓梦林

都看到这里了,支持一下作者呗~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值