首页 > 其他分享 >力扣 501. 二叉搜索树中的众数

力扣 501. 二叉搜索树中的众数

时间:2022-12-08 00:55:43浏览次数:60  
标签:cnt right res val 树中 力扣 众数 root 节点

501. 二叉搜索树中的众数

给你一个含重复值的二叉搜索树(BST)的根节点 root ,找出并返回 BST 中的所有 众数(即,出现频率最高的元素)。

如果树中有不止一个众数,可以按 任意顺序 返回。

假定 BST 满足如下定义:

  • 结点左子树中所含节点的值 小于等于 当前节点的值
  • 结点右子树中所含节点的值 大于等于 当前节点的值
  • 左子树和右子树都是二叉搜索树

示例 1:

输入:root = [1,null,2,2]
输出:[2]

示例 2:

输入:root = [0]
输出:[0]

提示:

  • 树中节点的数目在范围 [1, 104] 内
  • -105 <= Node.val <= 105

进阶:你可以不使用额外的空间吗?(假设由递归产生的隐式调用栈的开销不被计算在内)

题解

利用二叉搜索树的性质,进行中序遍历,得到一个升序序列。通过遍历cnt累计当前节点出现的次数,maxCnt记录最多次数。vector存储众数,通过变量lastVal与当前节点值对比,判断cnt是否继续累加。

  • cnt>maxCnt时更新最大值,并且清空vector,存入当前节点、
  • cnt=maxCnt时,存入当前节点,不需要清空。
查看代码
 /**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    vector<int> findMode(TreeNode* root) {
        vector<int> res;
        int cnt=0;//累计当前节点出现次数
        int maxxCnt=0;//最大出现次数
        int lastVal=root->val;//中序遍历上一个节点的值
        while (root != NULL)
        {
            if (root->left == NULL)
            {
                // cout << root->val << " ";//输出当前节点
                if(lastVal==root->val)
                    cnt++;
                else{
                    cnt=1;
                    lastVal=root->val;
                } 
                
                if(cnt>maxxCnt){//更新res和maxxCnt
                    res.clear();//清空res
                    res.emplace_back(root->val);
                    maxxCnt=cnt;
                }else if(cnt==maxxCnt)//多个众数
                {
                    res.emplace_back(root->val);
                }
                
                root = root->right;
            }
            else
            {
                // 找当前节点的前趋结点
                TreeNode* predecessor = root->left;
                while (predecessor->right != NULL
                    && predecessor->right != root)
                {
                    predecessor = predecessor->right;
                }

                // 使当前节点成为inorder的前序节点的右侧子节点
                if (predecessor->right == NULL)
                {
                    predecessor->right = root;
                    root = root->left;
                }
                //复原之前的修改
                else
                {
                    predecessor->right = NULL;
                    // cout << root->val << " ";//输出当前节点
                    if(lastVal==root->val)
                        cnt++;
                    else{
                        cnt=1;
                        lastVal=root->val;
                    }
                    if(cnt>maxxCnt){//更新res和maxxCnt
                        res.clear();//清空res
                        res.emplace_back(root->val);
                        maxxCnt=cnt;
                    }else if(cnt==maxxCnt)//多个众数
                    {
                        res.emplace_back(root->val);
                    }
                    root = root->right;
                }
            }
        }
        return res;
    }
};

标签:cnt,right,res,val,树中,力扣,众数,root,节点
From: https://www.cnblogs.com/fudanxi/p/16965014.html

相关文章

  • 力扣 230. 二叉搜索树中第K小的元素
    230.二叉搜索树中第K小的元素给定一个二叉搜索树的根节点 root ,和一个整数 k ,请你设计一个算法查找其中第 k 个最小元素(从1开始计数)。示例1:输入:root=......
  • 力扣 leetcode 78. 子集
    问题描述给你一个整数数组nums,数组中的元素互不相同。返回该数组所有可能的子集(幂集)。解集不能包含重复的子集。你可以按任意顺序返回解集。提示:1<=nums.le......
  • 力扣-77-组合
    直达链接这个问题应该就是我想找的答案了,把k=1~n全部输出一遍然后如果k=n,那就是全排列问题不对,还是不一样,这里只考虑数字组合,而没考虑数字顺序也就是排列问题两种解法,第......
  • 力扣 leetcode 1775. 通过最少操作次数使数组的和相等
    问题描述给你两个长度可能不等的整数数组nums1和nums2。两个数组中的所有值都在1到6之间(包含1和6)。每次操作中,你可以选择任意数组中的任意一个整数,将它变成......
  • 力扣540(java&python)-有序数组中的单一元素(中等)
    题目:给你一个仅由整数组成的有序数组,其中每个元素都会出现两次,唯有一个数只会出现一次。请你找出并返回只出现一次的那个数。你设计的解决方案必须满足O(logn)时间复......
  • linux不用设备树写中断,linux-kernel – 将设备树中断标志映射到devm_request_irq
    我目前正在为Linux使用PowerPC编写设备驱动程序.设备树条目如下://PPSInterruptclientpps_hwirq{compatible="pps-hwirq";interrupts=<170x02>;//IPIC1......
  • 力扣12 数字转为罗马数字
    力扣12数字转为罗马数字题目:罗马数字包含以下七种字符:I,V,X,L,C,D和M。字符数值I1V5X10L50C......
  • 力扣 leetcode 797. 所有可能的路径
    问题描述给你一个有n个节点的有向无环图(DAG),请你找出所有从节点0到节点n-1的路径并输出(不要求按特定顺序)graph[i]是一个从节点i可以访问的所有节点的列表(即从节......
  • 力扣 leetcode 130. 被围绕的区域
    问题描述给你一个m*n的矩阵board,由若干字符'X'和'O',找到所有被'X'围绕的区域,并将这些区域里所有的'O'用'X'填充。提示:m==board.lengthn==board[i......
  • 「查找表」字符串中不同整数的数目(力扣第1805题)
    本题为12月6日力扣每日一题题目来源:力扣第1805题题目tag:查找表双指针题面题目描述给你一个字符串word,该字符串由数字和小写英文字母组成。请你用空格替换每个不......