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

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

4个月前 (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)

原创内容 转载请注明出处

分享给朋友:

相关文章

力扣第1991题:寻找数组的中心索引 如何找到左右和相等的中心索引

力扣第1991题:寻找数组的中心索引 如何找到左右和相等的中心索引

题目解读给定一个整数数组,我们需要找到一个中心索引,使得该索引左侧所有元素的和等于右侧所有元素的和。如果不存在这样的索引,则返回-1。中心索引的定义不包含在左右两侧的和计算中。这个问题考察对数组遍历和...

力扣654:递归分治的艺术 如何用最大元素构建二叉树

力扣654:递归分治的艺术 如何用最大元素构建二叉树

题目重解我们面对一个看似简单却充满递归魅力的题目:给定一个不含重复元素的整数数组,需要构建一棵特殊的二叉树。这个树的每个父节点都必须是当前子数组中的最大元素,而它的左右子树则分别由该最大值左侧和右侧的...

力扣965题深度解析:单值二叉树的判断技巧

力扣965题深度解析:单值二叉树的判断技巧

重新解读题目 判断一棵二叉树是否为“单值二叉树”,即所有节点的值是否完全相同。题目看似简单,实则考验对树结构递归特性的理解。若一棵树的所有节点值相同,其必然满足:根节点与左右子树的值一致,且...

手搓双向链表代码全解析:从零开始实现双向链表数据结构(附注释与实战步骤)

一、简介和特点双向链表(Double Linked List)是一种基础的数据结构,它由多个节点组成,每个节点包含数据域、指向下一个节点的指针(next)和指向前一个节点的指针(last)。与单向链表...

力扣1302题:层数最深叶子节点的和 - 递归双遍历解法详解

力扣1302题:层数最深叶子节点的和 - 递归双遍历解法详解

内容简介本文详细解析了力扣1302题"层数最深叶子节点的和"的递归双遍历解法。通过先计算树的最大深度,再求该深度所有节点值的和,展示了如何高效解决这类树结构问题。文章包含完整注释代...

手搓顺序表实现栈 代码详解及新手教程——从原理到实现的完整指南

一、简介和特点顺序栈是一种基于数组实现的后进先出(LIFO)数据结构。通过动态数组管理存储空间,它具备以下特点:1. 数组存储:数据连续存储,支持随机访问,访问效率高。2. 动态扩容:当栈满时自动扩展...

发表评论

访客

看不清,换一张

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