力扣【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);
    }
}
相关推荐
一匹电信狗2 分钟前
【C++】手搓一个STL风格的vector容器
c语言·数据结构·c++·算法·leetcode·stl·visual studio
生信探索7 分钟前
SeuratExtend 可视化教程(1):单细胞分析的高颜值绘图指南
算法
BUG创建者7 分钟前
openlayer根据不同的状态显示不同的图层颜色
android·java·javascript
李永奉22 分钟前
C语言-数组:数组(定义、初始化、元素的访问、遍历)内存和内存地址、数组的查找算法和排序算法;
c语言·算法·排序算法
羊锦磊29 分钟前
[java 常用类API] 新手小白的编程字典
java
都叫我大帅哥31 分钟前
TOGAF技术架构阶段全解析:从理论到Java实战,避坑指南附赠!
java
星辰大海的精灵33 分钟前
深入解析 CopyOnWriteArrayList
java·后端·算法
都叫我大帅哥34 分钟前
Java ScopedValue:线程安全的"数据气泡"指南
java
Code季风36 分钟前
深入 Spring IoC 容器:六大关键应用场景助力项目开发
java·spring
这些不会的37 分钟前
iphone手机使用charles代理,chls.pro/ssl 后回车 提示浏览器打不开该网页
java