每日一题 501二叉搜素树中的众数(中序遍历)

题目

给你一个含重复值的二叉搜索树(BST)的根节点 root ,找出并返回 BST 中的所有 众数(即,出现频率最高的元素)。

如果树中有不止一个众数,可以按 任意顺序 返回。

假定 BST 满足如下定义:

  • 结点左子树中所含节点的值 小于等于 当前节点的值
  • 结点右子树中所含节点的值 大于等于 当前节点的值
  • 左子树和右子树都是二叉搜索树

示例 1:

复制代码
输入:root = [1,null,2,2]
输出:[2]

示例 2:

复制代码
输入:root = [0]
输出:[0]

题解

java 复制代码
/**
 * 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 {
    List<Integer> ans = new ArrayList<>();
    int cur = 0;
    int cnt = 0;
    int maxcnt = 0;
    public int[] findMode(TreeNode root) {
        dfs(root);
        //定义一个数组接收答案
        int[] res = new int[ans.size()];
        for(int i = 0; i < ans.size(); i++) {
            res[i] = ans.get(i);
        }
        return res;
    }
    private void dfs(TreeNode root) {
        if (root == null) {
            return;
        }
        dfs(root.left);
        if (root.val == cur) {
            cnt++;
        } else {
            cur = root.val;
            cnt = 1;
        }
        if (maxcnt == cnt) {
            ans.add(root.val);
        } else if (maxcnt < cnt) {
            //更新最大值
            ans.clear();
            ans.add(root.val);
            maxcnt = cnt;
        }
        dfs(root.right);
    }
}
相关推荐
lazily-c9 分钟前
Web后端开发总结
java·学习·web·1024程序员节
不是老弟29 分钟前
rwqsd
数据结构·c++·算法
小龙报32 分钟前
《C语言疑难点 --- 字符函数和字符串函数专题(上)》
c语言·开发语言·c++·算法·学习方法·业界资讯·visual studio
凭君语未可37 分钟前
深度解析Java的多态特性
java·开发语言
程序员阿鹏1 小时前
560.和为k的子数组
数据结构
zbh06041 小时前
洛谷P5788 【模板】单调栈——单调栈
数据结构·算法
xiaopengbc1 小时前
谷歌商店下载APK教程,先下载谷歌三件套,再直接从 Google Play 下载 APK 文件?
leetcode
华仔啊1 小时前
JVM参数到底配在哪?7大场景全解,新手不再迷茫!
java·jvm
moonsims2 小时前
Z3 Technology-适用于无人机和机器人的 4K 高清摄像机和视频编码器
算法