在BST(二叉搜索树)中查找介于给定范围之内的值

一、题目要求

编写一个递归函数printRange(),传入一个BST、一个较小的值和一个较大的值,按照顺序打印出介于两个值之间的所有结点。函数printRange()应尽可能少地访问BST的结点。(C++实现)

二、题解

代码如下:

void PrintRange(BinarySearchTree* bst,int minData,int maxData) {
        //中序 保证按大小顺序打印范围内的数
        while (bst->root) {
            BinaryTreeNode *pointer = bst->root;

            //向左子树查找,直到某棵左子树的根的值不大于给定的最小值
            if (pointer->value>minData){
                bst->root=pointer->lChild;
                PrintRange(bst,minData,maxData);
            }

            //如果值在范围内则打印输出
            if (pointer->value > minData && pointer->value < maxData)
                cout << pointer->value << " ";

            //向右子树查找,直到某棵右子树的根的值不小于给定的最大值
            if (pointer->value<maxData){
                bst->root=pointer->rChild;
                PrintRange(bst,minData,maxData);
            }

        }
    }
  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值