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;
    }
};
相关推荐
用户0203388613143 分钟前
红黑树主要功能实现
算法
꧁Q༒ོγ꧂4 分钟前
C++ 入门完全指南(六)--指针与动态内存
开发语言·c++
永远不打烊4 分钟前
c++ 11 之 并发与多线程
c++
专注VB编程开发20年7 分钟前
压栈顺序是反向(从右往左)的,但正因为是反向压栈,所以第一个参数反而离栈顶(ESP)最近。
java·开发语言·算法
Xの哲學8 分钟前
Linux Select 工作原理深度剖析: 从设计思想到实现细节
linux·服务器·网络·算法·边缘计算
say_fall12 分钟前
C++ 类与对象易错点:初始化列表顺序 / 静态成员访问 / 隐式类型转换
android·java·开发语言·c++
Paul_092027 分钟前
golang编程题
开发语言·算法·golang
颜酱31 分钟前
用填充表格法-继续吃透完全背包及其变形
前端·后端·算法
夏秃然34 分钟前
打破预测与决策的孤岛:如何构建“能源垂类大模型”?
算法·ai·大模型
ChoSeitaku38 分钟前
16.C++入门:list|手撕list|反向迭代器|与vector对比
c++·windows·list