leetcode刷题记录37-2476. 二叉搜索树最近节点查询

问题描述

给你一个 二叉搜索树 的根节点 root ,和一个由正整数组成、长度为 n 的数组 queries

请你找出一个长度为 n二维 答案数组 answer ,其中 answer[i] = [mini, maxi]

  • mini 是树中小于等于 queries[i]最大值 。如果不存在这样的值,则使用 -1 代替。
  • maxi 是树中大于等于 queries[i]最小值 。如果不存在这样的值,则使用 -1 代替。

返回数组 answer

示例

示例 1 :

复制代码
输入:root = [6,2,13,1,4,9,15,null,null,null,null,null,null,14], queries = [2,5,16]
输出:[[2,2],[4,6],[15,-1]]
解释:按下面的描述找出并返回查询的答案:
- 树中小于等于 2 的最大值是 2 ,且大于等于 2 的最小值也是 2 。所以第一个查询的答案是 [2,2] 。
- 树中小于等于 5 的最大值是 4 ,且大于等于 5 的最小值是 6 。所以第二个查询的答案是 [4,6] 。
- 树中小于等于 16 的最大值是 15 ,且大于等于 16 的最小值不存在。所以第三个查询的答案是 [15,-1] 。

示例 2 :

复制代码
输入:root = [4,null,9], queries = [3]
输出:[[-1,4]]
解释:树中不存在小于等于 3 的最大值,且大于等于 3 的最小值是 4 。所以查询的答案是 [-1,4] 。

提示:

  • 树中节点的数目在范围 [2, 10^5]
  • 1 <= Node.val <= 10^6
  • n == queries.length
  • 1 <= n <= 10^5
  • 1 <= queries[i] <= 10^6

问题分析:

刚做完一看运行时间1966ms,击败了19.57%。心说完了,自己想出来的无脑解法果然废了。。。然后一看官解,好好好,官解剽窃我的思路是吧。

我的思路就是:首先题目给了一个二叉搜索树,我们直接中序遍历把树节点值全存一个数组arr里,易知这个数组有序,接着直接二分查找对应结点即可。

代码如下:

cpp 复制代码
class Solution {
public:
    vector<vector<int>> closestNodes(TreeNode* root, vector<int>& queries) {
        vector<int> res;
        //    中序遍历存储有序数组
        function<void(TreeNode*)> inorder = [&](TreeNode* node) {
            if (node == nullptr)
                return;
            inorder(node->left);
            res.push_back(node->val);
            inorder(node->right);
        };
        inorder(root);
        //    结果数组
        vector<vector<int>> ans;
        for (int i = 0; i < queries.size(); ++i) {
            //    内置二分找大于等于元素,返回迭代器
            auto p = lower_bound(res.begin(), res.end(), queries[i]);
            //    如果找到了并且是对应元素本身
            if (p != res.end() && *p == queries[i]) {
                ans.push_back({*p, *p});
            //    否则push{lower,upper}
            } else {
                int lower = (p == res.begin()) ? -1 : *(p - 1);
                int upper = (p == res.end()) ? -1 : *p;
                ans.push_back({lower, upper});
            }
        }
        return ans;
    }
};
相关推荐
Brilliantwxx1 小时前
【C++】 继承与多态(中)
开发语言·c++·笔记·算法
青瓦梦滋8 小时前
C++的IO流与STL的空间配置器
开发语言·c++
鱼很腾apoc9 小时前
【学习篇】第20期 超详解 C++ 多态:从语法规则到底层原理
java·c语言·开发语言·c++·学习·算法·青少年编程
不吃土豆的马铃薯10 小时前
4.SGI STL 二级空间配置器 allocate 与_S_refill 源码解析
c语言·开发语言·c++·dreamweaver·内存池
小许同学记录成长11 小时前
三维重建技术文档
算法·无人机
fufu031111 小时前
vscode配置C/C++环境,用GDB调试简单程序分享
开发语言·c++
水云桐程序员13 小时前
C++变量的概念及用法
开发语言·c++
小O的算法实验室13 小时前
2026年ASOC,基于多目标优化去噪双存档进化算法+路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
水饺编程13 小时前
第5章,[Win32 章节] :几种典型的颜色
c语言·c++·windows·visual studio