今日算法(二叉树)

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;
    }
};
相关推荐
南境十里·墨染春水1 小时前
八大排序算法 - 基数排序
算法·排序算法
老四啊laosi1 小时前
[滑动窗口] 12. 将 x 减到 0 的最小操作数
算法·leetcode·将 x 减到 0 的最小操作数
一条大祥脚1 小时前
Codeforces Round 1098 (Div. 2)
算法·深度优先
时空自由民.1 小时前
平衡车PID控制系统(豆包版本)
算法
sno_guo2 小时前
直播抠图技术100谈之25---调色中曲线是最优解
人工智能·算法·机器学习·直播·内容运营·obs抠图·直播技术
故事和你912 小时前
洛谷-【图论2-2】最短路1
开发语言·数据结构·c++·算法·动态规划·图论
Simple-Soft2 小时前
指针的高级应用与技巧 - C语言的灵魂
c语言·数据结构·算法
南宫萧幕2 小时前
Simulink 从零搭建 HEV ECMS 环境:模块解析、排坑指南与智能算法接口预留
人工智能·算法·matlab·汽车·控制
子豪-中国机器人2 小时前
词云与条形码答案
算法