每日一题 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);
    }
}
相关推荐
Miraitowa_cheems1 小时前
LeetCode算法日记 - Day 73: 最小路径和、地下城游戏
数据结构·算法·leetcode·职场和发展·深度优先·动态规划·推荐算法
野蛮人6号2 小时前
力扣热题100道之560和位K的子数组
数据结构·算法·leetcode
Swift社区2 小时前
LeetCode 400 - 第 N 位数字
算法·leetcode·职场和发展
fengfuyao9853 小时前
BCH码编译码仿真与误码率性能分析
算法
Predestination王瀞潞3 小时前
Java EE开发技术(Servlet整合JDBC银行管理系统-上)
java·servlet·java-ee·jdbc
寻星探路3 小时前
Java EE初阶启程记13---JUC(java.util.concurrent) 的常见类
java·开发语言·java-ee
小白不想白a3 小时前
每日手撕算法--哈希映射/链表存储数求和
数据结构·算法
怪兽20144 小时前
什么是 Redis?
java·数据库·redis·缓存·面试
剪一朵云爱着4 小时前
力扣2080. 区间内查询数字的频率
算法·leetcode
Gu_yyqx4 小时前
Java 队列
java