美文网首页
剑指offer 58- 二叉搜索树的第k个结点

剑指offer 58- 二叉搜索树的第k个结点

作者: 顾子豪 | 来源:发表于2021-06-04 02:25 被阅读0次

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

你可以假设树和 k都存在,并且 1≤k≤树的总结点数。

样例

输入:root = [2, 1, 3, null, null, null, null] ,k = 3

    2
   / \
  1   3

输出:3

分析:
采用递归依次遍历左子树,根和右子树
每当访问根节点就让k--, 当k=0时,此时的根节点就是我们求得答案。
时间复杂度O(N)

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    TreeNode* res = new TreeNode(-1);
    TreeNode* kthNode(TreeNode* root, int k) {
        dfs(root, k);
        return res;
    }
    
    void dfs(TreeNode* root, int& k) {
        if(!root) return;
        dfs(root->left, k);
        if(!--k) res = root;
        dfs(root->right, k);
    }
};

相关文章

网友评论

      本文标题:剑指offer 58- 二叉搜索树的第k个结点

      本文链接:https://www.haomeiwen.com/subject/gownjltx.html