dfs专题5——(二叉搜索树中第 K 小的元素)

🔥近津薪荼: [个人主页] 🎬个人专栏: 《近津薪荼的算法日记》 《Linux操作系统及网络基础知识分享》 《c++基础知识详解》 《c语言基础知识详解》


1.上期参考代码

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    long  prev=LONG_MIN;//要取比int最小值还要小的值
    bool isValidBST(TreeNode* root) {
        if(root==nullptr)return true;//出口

        bool left=isValidBST(root->left);
        if(left==false)return false;//剪枝

        bool cur=false;
        if(root->val>prev)
        cur=true;

        if(cur==false) return false;//剪枝
        prev=root->val;
        bool right=isValidBST(root->right);

        return left&&right&&cur;
    }
};

2.本期知识点导图

3.本期要讲解的题目是

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

要点:

本题延续上期的思路,给大家练习一下剪枝的操作

4.解题

延续上期的思路,这题很简单

无非是中序遍历二叉搜索树,把遍历到的第六个元素返回即可。

代码逻辑:

创建两个全局变量,count与ret,在中序遍历的过程中不断维护

count:初始化:count=k

遍历一次就自减一次,遍历过程中进行逻辑判断,count为0到时候,对应的值就是第k小的值。

问:先count--还是先判断count是否为0?
ret:count==0时,存储要返回的值

全局变量的好处:

  • 简化函数头的设计,本题的函数头只有一个参数,且无返回值
  • 方便函数逻辑模块化,本题中的遍历逻辑是在类中新建一个成员函数实现的,给其传参即可,复杂的算法可以将一个大问题简化成多个小问题

5.下期要讲解的题目是:

二叉树的所有路径

6.嗟食

如果小编写的内容对佬有帮助,还请大佬点点三连加关注哦
佬的支持就是我前进的最大动力 ~

期待与佬的再次相遇~

相关推荐
Wect15 小时前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP1 天前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
端平入洛1 天前
delete又未完全delete
c++
颜酱1 天前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub2 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP2 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试