当前位置: 首页 > article >正文

力扣174. 寻找二叉搜索树中的目标节点(java,二叉搜索树的性质的运用)

Problem: LCR 174. 寻找二叉搜索树中的目标节点

文章目录

  • 思路
  • 解题方法即注意点
  • 复杂度
  • Code

思路

首先我们可以知道二叉搜索树的如下性质

1.若中序遍历先遍历左子树再右子树可以的到一个递增的序列
2.若中序遍历先遍历右子树再左子树可以的到一个递减的序列

所以我们得出如下思路:

1.以右-根-左的顺序中序递归遍历
2.在递归遍历的的过程中记录一个递增变量,当其为第cnt大的时,结束递归返回该节点值即可。

解题方法即注意点

大体解题方法见思路,注意下点可以优化代码

当记录的递增变量大于等于cnt时,即可退出递归达到一个减枝的效果

复杂度

  • 时间复杂度:

O ( n ) O(n) O(n)

  • 空间复杂度:

O ( n ) O(n) O(n)

Code


/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    //Time Complexity: O(n)
    //Space Complexity: O(n)

    int count = 0;
    int result;
    public int findTargetNode(TreeNode root, int cnt) {
        inorder(root,cnt);
        return result;
    }

    //二叉搜索树的中序遍历函数
    //左根右:从小到大
    //右根左:从大到小
    public void inorder(TreeNode root, int cnt) {
        //减枝:当count大于cnt时直接退出
        if (count >= cnt) return;
        if (root == null) return;
        //先遍历右子树
        inorder(root.right,cnt);
        count++;
        //再归的过程中查找是否存在
        if (count == cnt) {
            result = root.val;
            return;
        }
        inorder(root.left,cnt);
    }

}

http://www.kler.cn/a/134218.html

相关文章:

  • MySQL重难点(一)索引
  • 【vue2.0入门】vue基本语法
  • 【Vue】Vue3.0(十九)Vue 3.0 中一种组件间通信方式-自定义事件
  • ima.copilot-腾讯智能工作台
  • qt QVideoWidget详解
  • ODOO学习笔记(8):模块化架构的优势
  • vscode 创建 运行c++ 项目
  • 一文了解Word2vec 阐述训练流程
  • 第7天:信息打点-资产泄漏amp;CMS识别amp;Git监控amp;SVNamp;DS_Storeamp;备份
  • VBA之Word应用:文档(Document)的书签
  • 【Python数据结构与算法】——(线性结构)精选好题分享,不挂科必看系列
  • 函数式编程框架 functionaljava 简介
  • ClickHouse数据一致性
  • 电子学会C/C++编程等级考试2022年03月(一级)真题解析
  • linux文件IO
  • CentOS to 浪潮信息 KeyarchOS 迁移体验与优化建议
  • 【算法】二分查找-20231120
  • Leetcode—2760.最长奇偶子数组【简单】
  • ubuntu 20通过docker安装onlyoffice,并配置https访问
  • 基于Qt QList和QMap容器类示例
  • 关于缓存和数据库一致性问题的深入研究
  • 容斥 C. Strange Function改编题
  • 使用宝塔面板安装mysql
  • AI机器学习 | 基于librosa库和使用scikit-learn库中的分类器进行语音识别
  • Canal+Kafka实现MySQL与Redis数据同步(一)
  • 【洛谷 P1182】数列分段 Section II 题解(二分答案+递归)