二叉树:寻找二叉搜索树的众数

这篇博客探讨了在二叉搜索树中找到众数的方法,强调了在非二叉搜索树情况下,可以遍历树并使用map统计频率,然后按频率排序找出高频元素。对于二叉搜索树,利用前驱节点的概念,可以在不使用额外空间的情况下完成众数查找。文章提醒注意众数可能不止一个,并提供了处理这种情况的策略。
摘要由CSDN通过智能技术生成

501. 二叉搜索树中的众数

在这里插入图片描述
易错点:众数有可能不止一个!

如果不是二叉搜索树,是普通的树:

  1. 这个树都遍历了,用map统计频率
  2. 把统计的出来的出现频率(即map中的value)排个序
  3. 取前面高频的元素
class Solution {
   
public:
    vector<int> findMode(TreeNode* root) {
   
       
        unordered_map<int, int> map; // key:元素,value:出现频率
        vector<int> result;
        if (root == NULL) 
        return result;
        searchBST(root, map);
        vector<pair<int, int>> vec(map.begin(), map.end());
        sort(vec.begin()
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值