码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 894. All Possible Full Binary Trees


    Given an integer n, return a list of all possible full binary trees with n nodes. Each node of each tree in the answer must have Node.val == 0.

    Each element of the answer is the root node of one possible tree. You may return the final list of trees in any order.

    A full binary tree is a binary tree where each node has exactly 0 or 2 children.

    Example 1:

    Input: n = 7
    Output: [[0,0,0,null,null,0,0,null,null,0,0],[0,0,0,null,null,0,0,0,0],[0,0,0,0,0,0,0],[0,0,0,0,0,null,null,null,null,0,0],[0,0,0,0,0,null,null,0,0]]
    

    Example 2:

    Input: n = 3
    Output: [[0,0,0]]
    

    Constraints:

    • 1 <= n <= 20

    题目:给定正整数n。求包含n个节点的所有完全二叉树的结构。每个节点值为0. 完全二叉树是一个二叉树,其所有节点包含0个或2个子节点。

    思路:与96. Unique Binary Search Trees类似,采用动态规划方法,将n-1个节点分为左右子节点。采用递归方法分别求出从1到n-2个节点的完全二叉树结构,将其置于根节点的左右子树位置。为减少计算,使用hashmap来保存子树结构。小编使用一个vector> subTree结构来代替hashmap,subTree[i]即为包含i个节点的所有完全二叉树结构。为保证树结构为完全二叉树,i为奇数。代码:

    1. /**
    2. * Definition for a binary tree node.
    3. * struct TreeNode {
    4. * int val;
    5. * TreeNode *left;
    6. * TreeNode *right;
    7. * TreeNode() : val(0), left(nullptr), right(nullptr) {}
    8. * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
    9. * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
    10. * };
    11. */
    12. class Solution {
    13. private:
    14. vector> subTree;
    15. public:
    16. vector allPossibleFBT(int n) {
    17. if(subTree.size() > n && subTree[n].size() > 0)
    18. return subTree[n];
    19. while(subTree.size() <= n) subTree.push_back({});
    20. if(n == 1){
    21. subTree[1].push_back(new TreeNode(0));
    22. } else {
    23. for(int i = 1; i < n-1; i+=2){
    24. vector left = allPossibleFBT(i);
    25. vector right = allPossibleFBT(n-i-1);
    26. for(auto l : left){
    27. for(auto r : right){
    28. TreeNode* root = new TreeNode(0);
    29. root->left = l;
    30. root->right = r;
    31. subTree[n].push_back(root);
    32. }
    33. }
    34. }
    35. }
    36. return subTree[n];
    37. }
    38. };
  • 相关阅读:
    [Vue warn]: Error in render: “TypeError: renderEmpty is not a function“
    .NET 6学习笔记(1)——通过FileStream实现不同进程对单一文件的同时读写
    UE5 C++ 发射子弹发射(Projectile)
    TCP协议的核心机制
    【Java每日一题】——第十六题:将数组元素逆序并遍历输出。(2023.09.30)
    【光谱-空间交互网络:Pansharpening】
    在数据增强、蒸馏剪枝下ERNIE3.0分类模型性能提升
    Android 获取某月所有的日期和星期
    C# XML基础入门(XML文件内容增删改查清)
    wireshark图形界面介绍
  • 原文地址:https://blog.csdn.net/qing2019/article/details/126888347
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号