二叉搜索树的第 k 大的节点

发布于 2023-05-04 19:32:07 字数 756 浏览 49 评论 0

给定一棵二叉搜索树,请找出其中第 k 大的节点。

递归1

中序遍历所有值,得到所有数组,然后取倒数第k个

function kthLargest(root, k) {
    let res = [];
    const inorder = (root) => {
        if (root === null) {
            return;
        }
        inorder(root.left);
        res.push(root.val);
        inorder(root.right);
    }
    inorder(root);
    return res[res.length - k];
}

递归2

中序遍历倒序,找到最右边的节点,然后回溯

function kthLargest1(root, k) {
    let res = null
    const dfs = (root) => {
        if (!root) {
            return
        }
        dfs(root.right)
        if (k === 0) {
            return
        }
        if (--k === 0) {
            res = root.val
        }
        dfs(root.left)
    }
    dfs(root)

    return res
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

呆头

暂无简介

0 文章
0 评论
24 人气
更多

推荐作者

qq_eQNo9e

文章 0 评论 0

内心旳酸楚

文章 0 评论 0

mb_BlPo2I8v

文章 0 评论 0

alipaysp_ZRaVhH1Dn

文章 0 评论 0

alipaysp_VP2a8Q4rgx

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文