230. 二叉搜索树中第K小的元素

给定一个二叉搜索树的根节点 root ,和一个整数 k ,请你设计一个算法查找其中第 k 个最小元素(从 1 开始计数)。

示例 1:


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

> 代码


class Solution {
public:
    vector<int> res;
    int aaa;
    void traversal(TreeNode* root,int k){
        if(!root || res.size() >= k) return;
        traversal(root->left,k);
        res.push_back(root->val);
        if(res.size() == k) aaa = root->val;
        traversal(root->right,k);
    }
    int kthSmallest(TreeNode* root, int k) {
        traversal(root,k);
        return aaa;   
    }
};
posted @   xiazichengxi  阅读(4)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示
主题色彩