力扣【501. 二叉搜索树中的众数】Java题解

题目要求不使用额外空间。

思路:

可以两次遍历,第一次找到众数的节点个数,第二次找出众数数组。

但我们可以把这两次遍历改为一次遍历,就是找众数的节点个数时同时去更新众数数组,当maxCount等于count时,追加当前节点的值到众数数组中;当maxCount大于count时,将结果数组清空后加入当前节点。

代码:

csharp 复制代码
class Solution {
    int maxCount=0; //目前众数节点的个数
    int count;  //目前节点的个数
    ArrayList<Integer> list=new ArrayList<>(); //存放结果
    TreeNode preNode; //前一个节点,一开始没有
    public int[] findMode(TreeNode root) {
        find(root);
        //将集合转换为数组
        int[] res = new int[list.size()];
        for(int i=0;i<list.size();i++){
            res[i] = list.get(i);
        }
        return res;
    }
    public void find(TreeNode root) {
        //非空判断
        if(root == null) return;
        //遍历左子树
        find(root.left);
        //当前节点个数判断
        if(preNode!=null && preNode.val == root.val){
            count++;
        }else{
            count = 1;
        }
        //判断是否是众数,是则更新结果集合
        if(count == maxCount){
            list.add(root.val);
        }else if(count > maxCount){
            list = new ArrayList<>();
            list.add(root.val);
            maxCount = count;
        }
        preNode = root;
        //遍历右子树
        find(root.right);
    }
}
相关推荐
To_OC13 分钟前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
小bo波4 小时前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking5 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
用户938515635075 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC6 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥7 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
张不才7 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
地平线开发者8 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者9 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
shepherd1119 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构