C语言 | Leetcode C语言题解之第230题二叉搜索树中第K小的元素

题目:

题解:

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */

int search_num(struct TreeNode* root, int k, int *result, int num)
{
    if(num == k + 1)
    {
        return k + 1; // 已找到就不往下跑了
    }

    if(root->left)
    {
        num = search_num(root->left, k, result, num);
    }
    if(num == k)
    {
        *result =  root->val;
        return k + 1; // 已找到就不往下跑了
    }
    num++;
    if(root->right)
    {
        num = search_num(root->right, k, result, num);
    }

    return num;
}

int kthSmallest(struct TreeNode* root, int k) {
    int result = 0;

    search_num(root, k, &result, 1); // 开始寻找

    return result;
}
相关推荐
标标大人1 小时前
c语言中的局部跳转以及全局跳转
android·c语言·开发语言
huanxiangcoco3 小时前
55. 跳跃游戏
python·leetcode
__AtYou__4 小时前
Golang | Leetcode Golang题解之第413题等差数列划分
leetcode·golang·题解
banjin6 小时前
AI驱动TDSQL-C Serverless 数据库技术实战营-ai学生选课系统数据分析
c语言·人工智能·serverless
DdddJMs__1356 小时前
C语言 | Leetcode C语言题解之第413题等差数列划分
c语言·leetcode·题解
轩轶子6 小时前
【C-项目】网盘(一期,无限进程版)
服务器·c语言·网络
0224号比邻星6 小时前
[C语言]第十节 函数栈帧的创建和销毁一基础知识到高级技巧的全景探索
c语言·开发语言
QXH2000007 小时前
Leetcode—环形链表||
c语言·数据结构·算法·leetcode·链表
Wils0nEdwards8 小时前
Leetcode 缺失的第一个正整数
leetcode
爱编程的小新☆10 小时前
C语言内存函数
c语言·开发语言·学习