力扣【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);
    }
}
相关推荐
春日见16 小时前
丝滑快速拓展随机树 S-RRT(Smoothly RRT)算法核心原理与完整流程
人工智能·算法·机器学习·路径规划算法·s-rrt
Code小翊16 小时前
”回调“高级
算法·青少年编程
云里雾里!16 小时前
力扣 977. 有序数组的平方:双指针法的优雅解法
算法·leetcode·职场和发展
ZHE|张恒16 小时前
Spring Bean 生命周期
java·spring
q***385118 小时前
SpringCloud实战十三:Gateway之 Spring Cloud Gateway 动态路由
java·spring cloud·gateway
小白学大数据18 小时前
Python爬虫伪装策略:如何模拟浏览器正常访问JSP站点
java·开发语言·爬虫·python
一只侯子19 小时前
Face AE Tuning
图像处理·笔记·学习·算法·计算机视觉
jianqiang.xue19 小时前
别把 Scratch 当 “动画玩具”!图形化编程是算法思维的最佳启蒙
人工智能·算法·青少年编程·机器人·少儿编程
程序员西西19 小时前
SpringBoot接口安全:APIKey保护指南
java·spring boot·计算机·程序员·编程·编程开发
不许哈哈哈19 小时前
Python数据结构
数据结构·算法·排序算法