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;
}
相关推荐
北顾笙98011 分钟前
day28-数据结构力扣
数据结构·算法·leetcode
米粒114 分钟前
力扣算法刷题 Day 48(单调栈)
算法·leetcode·职场和发展
三品吉他手会点灯1 小时前
C语言学习笔记 - 8.C概述 - 学习的目标
c语言·笔记·学习
三品吉他手会点灯1 小时前
C语言学习笔记 - 10.C概述 - C语言课程总纲要
c语言·笔记·学习
流年如夢1 小时前
结构体:定义、使用与内存布局
c语言·开发语言·数据结构·c++·算法
三品吉他手会点灯1 小时前
C语言学习笔记 - 6.C概述 - C的重要性
c语言·笔记·学习
wuminyu2 小时前
专家视角看 Java 字节码与Class 文件格式
java·linux·c语言·jvm·c++
YSF2017_32 小时前
C语言-13-制作动态库
c语言·开发语言
『昊纸』℃2 小时前
C语言学习心得集合 篇1
c语言·算法·编程基础·学习心得·实践操作
Chase_______2 小时前
LeetCode 1456:定长子串中元音的最大数目
算法·leetcode