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

算法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

相关文章:

  • 滑模控制2021年12月8日
  • 【Python零基础】Python测试
  • ASP.NET Core 入门教学五 集成日志
  • OpenCV小练习:身份证号码识别
  • 【Android】使用 ADB 查看 Android 设备的 CPU 使用率
  • es的简易dsl语句
  • ESP32利用大模型做聊天机器人
  • 2024年最强网络安全学习路线,详细到直接上清华的教材!
  • 【软考】磁盘的类型
  • 构建Spring Boot应用的微服务服务依赖管理
  • Jenkins服务安装配置
  • NoSql数据库 - Redis Cluster集群详解及案例实现
  • linux 云主机 pip 安装配置 letsencrypt certbot 为多个域名生成免费 https 证书实录
  • 小实战项目-第二章2.1-IIC协议讲解? 什么是软件IIC 什么是硬件IIC 有什么区别如何编写代码--这章节主要讲解软件IIC,下一章节讲解硬件IIC协议
  • SpringBoot-读取配置文件方式
  • 深入理解Java序列化:从入门到实践
  • nuxt3模拟手机验证码
  • Java算法之鸡尾酒排序(Cocktail Sort,或称为双向冒泡排序)
  • 进制数基础知识 与 位运算(基础版)
  • 在内核态使用 intel avx2 加速内存操作
  • 马上评|什么才是地方文旅宣传的正确姿势
  • 五一“大车流”来了,今日午后G40沪陕高速开始迎来出沪高峰
  • 海口市政协党组成员、秘书长、机关党组书记汪娟被查
  • 力箭二号火箭成功进行满载起竖试验,计划今年首飞发射轻舟飞船
  • 运动健康|不同能力跑者,跑步前后营养补给差别这么大?
  • 外交部:美方应在平等、尊重和互惠的基础上同中方开展对话