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。

相关推荐
月挽清风8 小时前
代码随想录第十五天
数据结构·算法·leetcode
TracyCoder12310 小时前
LeetCode Hot100(34/100)——98. 验证二叉搜索树
算法·leetcode
We་ct11 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
努力学算法的蒟蒻14 小时前
day79(2.7)——leetcode面试经典150
算法·leetcode·职场和发展
2401_8414956414 小时前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列
2401_8414956414 小时前
【LeetCode刷题】二叉树的直径
数据结构·python·算法·leetcode·二叉树··递归
我是咸鱼不闲呀15 小时前
力扣Hot100系列19(Java)——[动态规划]总结(上)(爬楼梯,杨辉三角,打家劫舍,完全平方数,零钱兑换)
java·leetcode·动态规划
铉铉这波能秀16 小时前
LeetCode Hot100数据结构背景知识之列表(List)Python2026新版
数据结构·leetcode·list
仟濹16 小时前
算法打卡 day1 (2026-02-06 周四) | 算法: DFS | 1_卡码网98 可达路径 | 2_力扣797_所有可能的路径
算法·leetcode·深度优先
YuTaoShao17 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展