博客
关于我
微软面试模拟题: BST中找到比K大的第一个数
阅读量:242 次
发布时间:2019-03-01

本文共 171 字,大约阅读时间需要 1 分钟。

思路1:直接中序遍历。找到比K大的第一个就输出,时间复杂度是O(N)

思路2: 二叉搜索数的二分查找,如果当前根节点的值比要查找的值大,那么就到左子数中去找,同时维护当前的最大值,如果否,就右子数中去找。

比较根节点和k的大小,比k大就到左子树找,反之到右子树少,同时用一个变量保存比k大的值,如果之后再遇到比k大的就更新变量,最后输出就行。

转载地址:http://ijqv.baihongyu.com/

你可能感兴趣的文章
MySQL修改密码报错ERROR 1396 (HY000): Operation ALTER USER failed for ‘root‘@‘localhost‘
查看>>
Mysql全局优化参数
查看>>
MySQL全文索引实现简单版搜索引擎
查看>>
MySQL全面瓦解:安装部署与准备
查看>>
mysql共享锁与排他锁
查看>>
MySQL内存表使用技巧
查看>>
MySQL再叙(体系结构、存储引擎、索引、SQL执行过程)
查看>>
mysql出现错误的解决办法
查看>>
MySQL函数
查看>>
mysql函数汇总之字符串函数
查看>>
mysql函数汇总之数学函数
查看>>
mysql函数汇总之日期和时间函数
查看>>
mysql函数汇总之条件判断函数
查看>>
mysql函数汇总之系统信息函数
查看>>
MySQL函数简介
查看>>
mysql函数遍历json数组
查看>>
MySQL函数(转发)
查看>>
mysql分区表
查看>>
MySQL分层架构与运行机制详解
查看>>
mysql分库分表中间件简书_MySQL分库分表
查看>>