Leetcode 3319. K-th Largest Perfect Subtree Size in Binary Tree

  • [Leetcode 3319. K-th Largest Perfect Subtree Size in Binary Tree](#Leetcode 3319. K-th Largest Perfect Subtree Size in Binary Tree)
    • [1. 解题思路](#1. 解题思路)
    • [2. 代码实现](#2. 代码实现)

1. 解题思路

这一题其实就是一个很常见的树的遍历,我们自底向上遍历每一个子树,看看其是否是完美二叉树,然后如果是的话将其结果存储下来然后找出第k大的结果即可。

2. 代码实现

给出python代码实现如下:

python 复制代码
class Solution:
    def kthLargestPerfectSubtree(self, root: Optional[TreeNode], k: int) -> int:
        perfect_subtree = []
        
        def dfs(root):
            nonlocal perfect_subtree
            if root is None:
                return True, 0
            left_is_perfect, left_cnt = dfs(root.left)
            right_is_perfect, right_cnt = dfs(root.right)
            if left_is_perfect and right_is_perfect and left_cnt == right_cnt:
                perfect_subtree.append(left_cnt + right_cnt + 1)
                return True, left_cnt + right_cnt + 1
            else:
                return False, left_cnt + right_cnt + 1
            
        dfs(root)
        perfect_subtree = sorted(perfect_subtree, reverse=True)
        return perfect_subtree[k-1] if len(perfect_subtree) >= k else -1

提交代码评测得到:耗时129ms,占用内存17.3MB。

相关推荐
橘颂TA14 小时前
【剑斩OFFER】算法的暴力美学——两整数之和
算法·leetcode·职场和发展
Dream it possible!15 小时前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树的最小绝对差(85_530_C++_简单)
c++·leetcode·面试
xxxxxxllllllshi15 小时前
【LeetCode Hot100----14-贪心算法(01-05),包含多种方法,详细思路与代码,让你一篇文章看懂所有!】
java·数据结构·算法·leetcode·贪心算法
-森屿安年-18 小时前
LeetCode 283. 移动零
开发语言·c++·算法·leetcode
元亓亓亓21 小时前
LeetCode热题100--79. 单词搜索
算法·leetcode·职场和发展
2501_9411437321 小时前
缓存中间件Redis与Memcached在高并发互联网系统优化与实践经验分享
leetcode
Elias不吃糖1 天前
LeetCode每日一练(209, 167)
数据结构·c++·算法·leetcode
野蛮人6号1 天前
力扣热题100道前62道,内容和力扣官方稍有不同,记录了本人的一些独特的解法
数据结构·算法·leetcode
CoderYanger1 天前
优选算法-栈:69.验证栈序列
java·开发语言·算法·leetcode·职场和发展·1024程序员节
2501_941803621 天前
Python高性能大数据分析与Pandas实战分享:海量数据处理、清洗与优化经验
leetcode