C++速通LeetCode中等第25题-验证二叉搜索树(中序遍历堆栈迭代法)

cpp 复制代码
class Solution {
public:
    int kthSmallest(TreeNode* root, int k) {
        stack<TreeNode *> stack;
        while (root != nullptr || stack.size() > 0) {
            while (root != nullptr) {
                stack.push(root);
                root = root->left;
            }
            root = stack.top();
            stack.pop();
            --k;
            if (k == 0) {
                break;
            }
            root = root->right;
        }
        return root->val;
    }
};
相关推荐
PPPPickup2 分钟前
easychat---创建,获取,获取详细,退群,解散,添加与移除群组
java·开发语言·后端·maven
liulilittle1 小时前
C++ 并发双阶段队列设计原理与实现
linux·开发语言·c++·windows·算法·线程·并发
森G1 小时前
五、Linux字符设备驱动
linux·arm开发·c++·ubuntu
lly2024061 小时前
并查集快速查找
开发语言
繁星蓝雨1 小时前
我与C++的故事(杂谈)
开发语言·c++
除了代码啥也不会1 小时前
Java基于SSE流式输出实战
java·开发语言·交互
尋有緣1 小时前
力扣2292-连续两年有3个及以上的订单产品
leetcode·oracle·数据库开发
Jacob程序员1 小时前
欧几里得距离算法-相似度
开发语言·python·算法
Slow菜鸟1 小时前
Java项目基础架构(二)| 通用响应与异常
java·开发语言
LQxdp2 小时前
复现-[Java Puzzle #2 WP] HEAD权限绕过与字符截断CRLF
java·开发语言·漏洞复现·java 代码审计