当前位置: 首页 > article >正文

算法day17|如何求普通二叉树的众数

算法day17|如何求普通二叉树的众数

  • 501的变式:普通二叉树的众数

501的变式:普通二叉树的众数

如果把二叉搜索树变成普通二叉树,我们该怎么思考呢?这个时候就要回到我一开始的思路了,用哈希表来解决问题。

class Solution {
public:
    unordered_map<int,int> map;
    void traversal(TreeNode* root)
    {
        if(root==nullptr)
        return;
        map[root->val]++;
        traversal(root->left);
        traversal(root->right);
        return;
    }
    bool static cmp(pair<int,int>&a,pair<int,int>&b)
    {
        return a.second>b.second;
    }

    vector<int> findMode(TreeNode* root) {
        vector<int> result;
        if(root==nullptr)
        return result;
        traversal(root);
        vector<pair<int,int>> vec(map.begin(),map.end());
        sort(vec.begin(),vec.end(),cmp);
        result.push_back(vec[0].first);
        for(int i=1;i<vec.size();i++)
        {
            if(vec[i].second==vec[0].second)
            result.push_back(vec[i].first);
            else
            break;
        }
        return result;
    }
};

总体思路:

  • 首先,用哈希表来记录二叉树的元素及其个数
  • 其次,对哈希表进行排序。由于哈希表的值是不能直接实现排序的,所以我们要**先把哈希表整个存在vector<pair<int,int>>**中,然后用sort函数来对vector排序即可(另外,sort的排序规则是需要单独写的)
  • 排序之后取前面相同的项的键即可

代码细节:

  • 哈希表的插入
map[root->val]++;

这是最简化的形式,map[键],中括号内是键,而map[键]整体就是对应的值,所以可以map[“coffee”]=1;或者map[root->val]++;

  • pair<int,int>也是可以作为一种数据类型的,可以代入函数里面,也可以作为vector的数据类型。本质上和int、double没有区别

  • sort函数

  sort(vec.begin(),vec.end(),cmp);

它有三个参数begin, end(区间左闭右开), cmp。其中,cmp参数为排序规则(cmp参数可以不写,如果不写的话,默认从小到大进行排序),如果是想要从大到小的排序,则需要写greater()(即:sort(begin,end,greater()))此处我们需要另写函数,因为数据类型比较特殊。

对于pair<int,int>,函数重写格式:

  bool static cmp(pair<int,int>&a,pair<int,int>&b)
          {
              return a.second>b.second;
          }

函数开头的bool static要注意

  • 如果以vector作为函数返回值的话,不能返回null

http://www.kler.cn/news/285267.html

相关文章:

  • DevOps实现CI/CD实战(二)-Jenkins配置
  • 鸿蒙( API 12 Beta5版)开发实战-UI优化布局性能
  • 视频中间件:与海康ISC平台级联
  • linux文件——文件系统——学习、理解、应用软硬件链接
  • 2025届北森智鼎SHL牛客倍智易考智联题库、十大测评系统通关攻略
  • 数值分析笔记(六)非线性方程求根
  • 周末总结(2024/08/31)
  • C语言 | Leetcode C语言题解之第383题赎金信
  • 宿舍|基于SprinBoot+vue的宿舍管理系统(源码+数据库+文档)
  • 访问者模式详解
  • 【摸鱼笔记】python 提取和采集 finereport 未绑定目录的报表模板
  • GPT-SoVITS:零样本语音合成AI
  • 如何使用pytest的fixtures以及pytest-dependency插件来管理接口之间的依赖关系(下)
  • V8 引擎的核心架构
  • DCB简介
  • Python入门全解析丨Part3-Python的循环语句
  • 英语2-小作文
  • Java | Leetcode Java题解之第386题字典序排数
  • 性能优化笔记二(本地缓存)
  • 05:【江科大stm32】:定时器输出比较功能(PWM)
  • Android 优化之 查找so 文件的来源
  • Camtasia 2024 v2024.0.6 for Mac 中文版 屏幕录像视频录制编辑软件
  • 找出两个序列的中位数
  • Python3.0以后各个版本区别介绍
  • 网络模型及协议介绍
  • STM32原理图一些引脚VDDA/VSSA/VBAT/OSC/NRST/BOOT
  • 随手记录第十五话 -- Spring Boot 3.2.3+Grafana+Prometheus+Loki实现一套轻量级监控加日志收集系统
  • 波导阵列天线单元学习笔记7 一种用直接金属激光烧结考虑的轻质量,宽带,双圆极化波导腔体阵列
  • Datawhale X 李宏毅苹果书 AI夏令营 Task2打卡
  • c++命令模式