力扣【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);
    }
}
相关推荐
董董灿是个攻城狮4 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
怒放吧德德6 小时前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty
雨中飘荡的记忆7 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
心之语歌10 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
华仔啊11 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang11 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构
AI软著研究员11 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish11 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
Ray Liang12 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
颜酱12 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法