• 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.

    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. };
  • 相关阅读:
    【控制】滑模控制,小例子,有程序有结果图
    解决TP-LINK配置DDNS失败的问题
    TypeScript语法快速上手
    GitHub配置账号Pull Request更新代码分支
    如何将高效设计应用于 DAO?
    postgresql autovaccum自动清理
    J2EE项目部署与发布(Windows版本)
    Linux-Cgroup V2 初体验
    设计模式入门(二)观察者模式
    mysql存储结构索引案例,回表
  • 原文地址:https://blog.csdn.net/qing2019/article/details/126888347