LEETCODE 49场周赛 第K大完美二叉子树的大小

这个题目本身很直接,谨以此题来熟练一下二叉树的相关操作的使用,好久没写二叉树的代码了,不熟练了有点,题目如下:题目链接传送门在这里题目链接传送门

给你一棵 二叉树 的根节点 root 和一个整数k。

返回第 k 大的 完美二叉子树的大小,如果不存在则返回 -1。

完美二叉树 是指所有叶子节点都在同一层级的树,且每个父节点恰有两个子节点。

子树 是指树中的某一个节点及其所有后代形成的树。

分析:其实简单分析一下哈,这个完美二叉树就是我们的完全二叉树的定义嘛,所以我们只需要判定每个节点是否是完全二叉树,然后返回其高度h,就可以根据这个高度h得到其节点个数为(2 ^h - 1),然后进行排序就好。

具体代码如下:(实现细节详见代码注释)

cpp 复制代码
/**
 * 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:
     //这个函数是去判断该子树是否是完全二叉树的,是的话就返回子树高度,否则返回-1
    int getHeight(TreeNode* root) {
        if (!root) return 0;
        int leftHeight = getHeight(root->left);
        int rightHeight = getHeight(root->right);
        if (leftHeight == -1 || rightHeight == -1 || leftHeight != rightHeight) {
            return -1; // 不是完美二叉树
        }
        return leftHeight + 1; // 是完美二叉树,高度加1
    }

    // 递归函数来计算完美二叉子树的大小,根据height返回 完全二叉树的高度
    int getPerfectSubtreeSize(TreeNode* root) {
        int height = getHeight(root);
        if (height == -1) {
            return 0; // 不是完美二叉树,大小为0
        }
        // 完美二叉树的节点总数为 2^height - 1
        return (1 << height) - 1;
    }

    // 主函数
    int kthLargestPerfectSubtree(TreeNode* root, int k) {
        vector<int> sizes;
        findPerfectSubtrees(root, sizes);
        // 对所有完美二叉子树的大小进行排序
        sort(sizes.rbegin(), sizes.rend());
        // 返回第 k 大的完美二叉子树的大小
        return (k <= sizes.size()) ? sizes[k - 1] : -1;
    }

    private:
    // 辅助函数,递归查找所有完美二叉子树,遍历整个二叉树,采用的是前序遍历,把所有合法节点的节点数目保存到sizes数组里面
        void findPerfectSubtrees(TreeNode* root, vector<int>& sizes) {
            if (!root) return;
            int size = getPerfectSubtreeSize(root);
            if (size > 0) {
                sizes.push_back(size);
            }
            // 继续递归查找左右子树
            findPerfectSubtrees(root->left, sizes);
            findPerfectSubtrees(root->right, sizes);
        }

};
相关推荐
一个不知名程序员www32 分钟前
算法学习入门---vector(C++)
c++·算法
云飞云共享云桌面39 分钟前
无需配置传统电脑——智能装备工厂10个SolidWorks共享一台工作站
运维·服务器·前端·网络·算法·电脑
福尔摩斯张1 小时前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
橘颂TA1 小时前
【剑斩OFFER】算法的暴力美学——两整数之和
算法·leetcode·职场和发展
Dream it possible!2 小时前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树的最小绝对差(85_530_C++_简单)
c++·leetcode·面试
xxxxxxllllllshi2 小时前
【LeetCode Hot100----14-贪心算法(01-05),包含多种方法,详细思路与代码,让你一篇文章看懂所有!】
java·数据结构·算法·leetcode·贪心算法
前端小L2 小时前
图论专题(二十二):并查集的“逻辑审判”——判断「等式方程的可满足性」
算法·矩阵·深度优先·图论·宽度优先
铁手飞鹰2 小时前
二叉树(C语言,手撕)
c语言·数据结构·算法·二叉树·深度优先·广度优先
专业抄代码选手3 小时前
【Leetcode】1930. 长度为 3 的不同回文子序列
javascript·算法·面试
[J] 一坚4 小时前
深入浅出理解冒泡、插入排序和归并、快速排序递归调用过程
c语言·数据结构·算法·排序算法