【手把手带你刷好题】—— 49.二叉搜索树的范围和(DFS+BFS)

举报
安然无虞 发表于 2022/05/26 23:53:50 2022/05/26
【摘要】 【前言】 今天是刷题打卡第49天! 感谢老铁们的支持与陪伴,加油鸭。   原题:二叉搜索树的范围和(DFS+BFS)  原题链接:力扣  题目描述:   示例1:   输入:root = [10,5,15,3,7,null,18], low = ...

【前言】

今天是刷题打卡第49天!

感谢老铁们的支持与陪伴,加油鸭。

 

原题:二叉搜索树的范围和(DFS+BFS) 

原题链接:力扣 

题目描述:

 

示例1:

 


  
  1. 输入:root = [10,5,15,3,7,null,18], low = 7, high = 15
  2. 输出:32

 示例2:


  
  1. 输入:root = [10,5,15,3,7,13,18,1,null,6], low = 6, high = 10
  2. 输出:23

方法一:DFS

之前写过DFS解法,所以在这里就直接给出链接咯。

【手把手带你刷LeetCode】——11.二叉搜索树的范围和(DFS)_安然无虞的博客-CSDN博客【前言】https://blog.csdn.net/weixin_57544072/article/details/121202376

注意:二叉搜索树的特点就是左子树都比根要小,右子树都比根要大! 

方法二:BFS

思路:

使用广度优先搜索的方法,用一个队列 q 存储需要计算的节点。每次取出队首节点时,若节点为空则跳过该节点,否则按方法一中给出的大小关系来决定加入队列的子节点。

代码执行:


  
  1. /**
  2. * Definition for a binary tree node.
  3. * struct TreeNode {
  4. * int val;
  5. * TreeNode *left;
  6. * TreeNode *right;
  7. * TreeNode() : val(0), left(nullptr), right(nullptr) {}
  8. * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
  9. * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
  10. * };
  11. */
  12. class Solution {
  13. public:
  14. int rangeSumBST(TreeNode* root, int low, int high) {
  15. queue<TreeNode*>q;//定义一个队列
  16. //首先将根节点入队
  17. if(root)
  18. q.push(root);
  19. int res = 0;
  20. while(!q.empty())//队列非空时循环继续
  21. {
  22. int n = q.size();//队列的长度
  23. for(int i = 0; i < n; i++)
  24. {
  25. TreeNode* t = q.front();//访问队首元素
  26. q.pop();//队首元素出队
  27. //注意输入格式中有空节点,所以要加一个判断
  28. //当访问到的节点是空节点时,跳过该节点
  29. if(t == nullptr)
  30. {
  31. continue;
  32. }
  33. //注意哦,由于是二叉搜索树,有它自己的特性
  34. //节点的值大于high时,只需要左子树入队
  35. if(t->val > high)
  36. q.push(t->left);
  37. //节点的值小于low时,只需要右子树入队
  38. if(t->val < low)
  39. q.push(t->right);
  40. //节点的值在low和high之间时,需要加上该节点值以及左右子树入队
  41. if(t->val >= low && t->val <= high)
  42. {
  43. res += t->val;
  44. q.push(t->left);
  45. q.push(t->right);
  46. }
  47. }
  48. }
  49. return res;
  50. }
  51. };

结语

今天是刷题打卡第49天!

加油吧少年。

 

 

文章来源: bit-runout.blog.csdn.net,作者:安然无虞,版权归原作者所有,如需转载,请联系作者。

原文链接:bit-runout.blog.csdn.net/article/details/121860395

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。