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

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

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

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

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

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

你可能感兴趣的文章
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql sysbench测试安装及命令
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
MySQL Troubleshoting:Waiting on query cache mutex
查看>>
mysql union orderby 无效
查看>>
mysql v$session_Oracle 进程查看v$session
查看>>
mysql where中如何判断不为空
查看>>
MySQL Workbench 使用手册:从入门到精通
查看>>
MySQL Workbench 数据库建模详解:从设计到实践
查看>>
MySQL Workbench 数据建模全解析:从基础到实践
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
查看>>
MySQL _ MySQL常用操作
查看>>
MySQL – 导出数据成csv
查看>>
MySQL —— 在CentOS9下安装MySQL
查看>>
MySQL —— 视图
查看>>
mysql 不区分大小写
查看>>