今日算法(二叉树)

cpp 复制代码
class Solution {
public:
    void Traversal(TreeNode* root, unordered_map<int, int>& m) {
        if (root == nullptr) return;
        m[root->val]++;
        Traversal(root->left, m);
        Traversal(root->right, m);
    }

    vector<int> findMode(TreeNode* root) {
        unordered_map<int, int> m;
        Traversal(root, m);
        
        // 找最大出现次数(正确遍历 map)
        int maxCount = 0;
        for (auto& pair : m) {
            maxCount = max(maxCount, pair.second);
        }

        // 收集所有众数
        vector<int> res;
        for (auto& pair : m) {
            if (pair.second == maxCount) {
                res.push_back(pair.first);
            }
        }

        return res;
    }
};

递归使用map存放出现的次数,然后进行遍历放入数组中,时间复杂度为O(N)

cpp 复制代码
class Solution {
public:
int count,maxcount;
TreeNode*pre=nullptr;
vector<int> vec;

void searchBST(TreeNode*root)
{
    if(root==NULL) return;
    searchBST(root->left);

//因为是二叉搜索树,所以都是邻近比较
     if(pre==NULL)
     {
        count=1;
     }
     else if(pre->val==root->val)
     {
        count++;
     }
     else//重新值一
     {
        count=1;
     }

     pre=root;

     if(count==maxcount)//目前的最大值插入
     {
        vec.push_back(root->val);
     }

     if(count>maxcount)
     {
        maxcount=count;
        vec.clear();//之前的值都作废
        vec.push_back(root->val);
     }

     searchBST(root->right);
     return;
}

    vector<int> findMode(TreeNode* root) {
        //使用前后指针进行记录大小,进行替换
        count=0;
        maxcount=0;
        pre=NULL;
vec.clear();
searchBST(root);
return vec;
    }
};

使用前后指针进行记录。

下面是迭代法

cpp 复制代码
class Solution {
public:
    vector<int> findMode(TreeNode* root) {
        stack<TreeNode*> st;
        TreeNode* cur = root;
        TreeNode* pre = NULL;
        int maxCount = 0; // 最大频率
        int count = 0; // 统计频率
        vector<int> result;
        while (cur != NULL || !st.empty()) {
            if (cur != NULL) { // 指针来访问节点,访问到最底层
                st.push(cur); // 将访问的节点放进栈
                cur = cur->left;                // 左
            } else {
                cur = st.top();
                st.pop();                       // 中
                if (pre == NULL) { // 第一个节点
                    count = 1;
                } else if (pre->val == cur->val) { // 与前一个节点数值相同
                    count++;
                } else { // 与前一个节点数值不同
                    count = 1;
                }
                if (count == maxCount) { // 如果和最大值相同,放进result中
                    result.push_back(cur->val);
                }

                if (count > maxCount) { // 如果计数大于最大值频率
                    maxCount = count;   // 更新最大频率
                    result.clear();     // 很关键的一步,不要忘记清空result,之前result里的元素都失效了
                    result.push_back(cur->val);
                }
                pre = cur;
                cur = cur->right;               // 右
            }
        }
        return result;
    }
};
相关推荐
sheeta19982 分钟前
LeetCode 补拙笔记 日期:2026.06.07 题目:283. 移动零
笔记·算法·leetcode
黎阳之光科技管控17 分钟前
纯视觉定位赋能海关口岸 无感通关提升国门安全与效率
算法·安全
晚风吹红霞26 分钟前
深入浅出 STL 之 map 与 set:从入门到实战
开发语言·c++
じ☆冷颜〃27 分钟前
Picard–Lindelöf定理在CS中的应用:理论框架与算法基础
人工智能·经验分享·笔记·算法·机器学习
牛油果子哥q30 分钟前
【C++封装】C++封装思想与访问权限终极精讲:public/private/protected权限解析、类封装设计、继承权限变化、工程私有化规范与面试坑点
c++·面试
织梦旅途30 分钟前
C++ 第一课 从 Hello Word!立刻开始
c++
不知名的老吴32 分钟前
机器学习评价之基础指标
人工智能·算法·机器学习
Felven32 分钟前
D. Divisible Pairs
算法
源代码杀手33 分钟前
基于ROS2+Gazebo+RIVE的40项计算机视觉前沿机器人项目(含视觉算法原理与源码获取方式)
算法·计算机视觉·机器人
.千余33 分钟前
【C++】 String 常用操作:增删查改 | 查找 | 截取 | IO
java·服务器·开发语言·c++·笔记·学习