Lintcode11 Search Range in Binary Search Tree solution 题解

发布时间:2020-07-21 16:19:30 作者:coderer
来源:网络 阅读:263

【题目描述】

Given two values k1 and k2 (where k1 < k2) and a root pointer to a Binary Search Tree. Find all the keys of tree in range k1 to k2. i.e. print all x such that k1<=x<=k2 and x is a key of given BST. Return all the keys in ascending order.

给定两个值 k1 和 k2(k1 < k2)和一个二叉查找树的根节点。找到树中所有值在 k1 到 k2 范围内的节点。即打印所有x (k1 <= x <= k2) 其中 x 是二叉查找树的中的节点值。返回所有升序的节点值。

【题目链接】

http://www.lintcode.com/en/problem/search-range-in-binary-search-tree/

【题目解析】

中等偏易难度题,本题涉及到二叉查找树的按序输出,应马上联想到二叉树的中序遍历,对于二叉查找树而言,使用中序遍历即可得到有序元素。对每次访问的元素加以判断即可得最后结果,由于 OJ 上给的模板不适合递归处理,新建一个私有方法即可。

D & C。若root值比k1小,则只搜root右子树,若root值比k2大,则只搜root左子树,否则左右子树都搜,然后先加左子树返回的答案,再加root,最后加右子树返回的答案。

剪枝的判断条件容易出错,应将当前节点的值与k1和k2进行比较而不是其左子节点或右子节点的值。

【答案链接】

http://www.jiuzhang.com/solutions/search-range-in-binary-search-tree/


推荐阅读:
  1. MySQL WHERE语句筛选操作符是怎样的
  2. where子句的使用

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

where solution values

上一篇:自动生成 java 项目 markdown 文档框架-01-入门使用

下一篇:Hive Hue的导出XLS格式,数据不全

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》