当前位置:首页 > 力扣 > 力扣501题最优解:不用额外空间找出BST中的众数?这个解法让你大开眼界

力扣501题最优解:不用额外空间找出BST中的众数?这个解法让你大开眼界

9个月前 (05-30)

力扣501题最优解:不用额外空间找出BST中的众数?这个解法让你大开眼界 二叉搜索树 二叉树 二叉树遍历 数据结构 算法 中序遍历 深搜 映射 第1张

题目解读‌:
二叉搜索树的世界里,每个节点都默默记录着自己的数值。现在我们需要找出这些数值中出现频率最高的那些数字,也就是所谓的"众数"。有趣的是,二叉搜索本身具有左小右大的特性,这为我们解决问题提供了天然的便利。题目要求我们找出所有出现次数最多的元素,当多个数字出现次数相同时,需要全部返回。

解题思路‌:
采用中序遍历+频率统计的经典解法。首先通过中序遍历将BST的所有节点值按升序存入数组,这个过程中BST的有序特性得到了充分利用。接着,代码使用一个足够大的数组来统计每个数值出现的频率,这里巧妙地将数值范围[-100000,100000]映射到数组索引[0,200000]。统计完所有数值的频率后,找出最大出现次数,最后收集所有达到这个最大次数的数值。这种方法虽然使用了额外空间,但思路清晰,实现简单,是解决此类问题的典型范例。

代码注释:

class Solution {
public:
    vector<int> tree; // 存储中序遍历结果的容器
    int sum[200001]={0}; // 频率统计数组,覆盖[-100000,100000]范围
    
    // 中序遍历二叉搜索树
    void inorder(TreeNode* root) {
        if(!root) return; // 递归终止条件
        inorder(root->left); // 遍历左子树
        tree.push_back(root->val); // 将当前节点值加入数组
        inorder(root->right); // 遍历右子树
    }
    
    vector<int> findMode(TreeNode* root) {
        vector<int> ret; // 结果容器
        inorder(root); // 执行中序遍历
        
        // 统计每个数值出现的频率
        for(int i=0;i<tree.size();i++)
            sum[tree[i]+100000]++; // 数值+100000映射到数组索引
            
        int maxsum=0; // 记录最大出现次数
        // 找出最大出现次数
        for(int i=0;i<200001;i++)
            maxsum=max(maxsum,sum[i]);
            
        // 收集所有出现次数等于maxsum的数值
        for(int i=0;i<200001;i++)
            if(sum[i]==maxsum) ret.push_back(i-100000); // 还原原始数值
            
        return ret; // 返回结果
    }
};


参考:力扣501题 解题思路和步骤 C++代码实现,力扣(leetcode)

原创内容 转载请注明出处

分享给朋友:

相关文章

力扣1221:一次扫描解决分割平衡字符串 时间O(n)空间O(1)

力扣1221:一次扫描解决分割平衡字符串 时间O(n)空间O(1)

题目重解给定一个仅包含'L'和'R'的字符串,要求将其分割成尽可能多的子串,且每个子串中'L'和'R'的数量相等。例如输入"R...

力扣145:递归之美 轻松掌握二叉树后序遍历

力扣145:递归之美 轻松掌握二叉树后序遍历

题目解读二叉树的后序遍历是一种基础且重要的树遍历方式,其遍历顺序为:先递归地后序遍历左子树,然后递归地后序遍历右子树,最后访问根节点。这种遍历方式特别适合需要先处理子节点再处理父节点的场景,如内存释放...

力扣540题:线性扫描法如何高效定位唯一数

力扣540题:线性扫描法如何高效定位唯一数

题目重解一个严格递增的有序数组中,除某个元素外,其余每个元素均出现两次。这个看似简单的条件背后隐藏着巧妙的规律——单一元素会打破数组的"成对对称性"。题目要求以O(log n)时间...

手把手教你实现头插法树:从代码到原理的深度解析

一、简介和特点头插法树是一种基于链表实现的树形数据结构,其核心思想是通过链表头插法管理节点的孩子节点。在本文的代码示例中,我们使用C++模板类实现了树结构,每个树节点(treenode<T>...

洛谷P1141题解:迷宫连通块问题的深度优先搜索算法与代码解析

洛谷P1141题解:迷宫连通块问题的深度优先搜索算法与代码解析

一、题目解读洛谷P1141题目要求处理一个由字符构成的迷宫,其中相同字符形成连通块,不同字符构成分隔。题目需统计连通块数量及大小,并支持查询两点是否属于同一连通块。核心在于高效识别并标记迷宫中的连通区...

手把手教你用链表实现栈:从步骤讲解到实战应用(新手友好版)

一、简介和特点链表栈是一种基于链表实现的数据结构,结合了栈的“先进后出(LIFO)”特性和链表的动态内存分配优势。相比数组实现的栈,链表栈无需提前指定固定容量,可动态扩展,插入和删除操作效率高,尤其适...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。