• 入门力扣自学笔记114 C++ (题目编号623)


    623. 在二叉树中增加一行

    题目:

    给定一个二叉树的根 root 和两个整数 val 和 depth ,在给定的深度 depth 处添加一个值为 val 的节点行。

    注意,根节点 root 位于深度 1 。

    加法规则如下:

    给定整数 depth,对于深度为 depth - 1 的每个非空树节点 cur ,创建两个值为 val 的树节点作为 cur 的左子树根和右子树根。
    cur 原来的左子树应该是新的左子树根的左子树。
    cur 原来的右子树应该是新的右子树根的右子树。
    如果 depth == 1 意味着 depth - 1 根本没有深度,那么创建一个树节点,值 val 作为整个原始树的新根,而原始树就是新根的左子树。


    示例 1:

    输入: root = [4,2,6,3,1,5], val = 1, depth = 2
    输出: [4,1,1,2,null,null,6,3,1,5]


    示例 2:

    输入: root = [4,2,null,3,1], val = 1, depth = 3
    输出:  [4,2,null,1,1,3,null,null,1]


    提示:

    节点数在 [1, 104] 范围内
    树的深度在 [1, 104]范围内
    -100 <= Node.val <= 100
    -105 <= val <= 105
    1 <= depth <= the depth of tree + 1


    来源:力扣(LeetCode)
    链接:https://leetcode.cn/problems/add-one-row-to-tree
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。


    思路:

    简单的采取BFS或者DFS即可。


    代码:

    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. public:
    14. TreeNode* addOneRow(TreeNode* root, int val, int depth) {
    15. if(depth==0 || depth==1){
    16. TreeNode* t = new TreeNode(val);
    17. if(depth==1)
    18. t->left = root;
    19. else
    20. t->right = root;
    21. return t;
    22. }
    23. if(root && depth>1){
    24. root->left = addOneRow(root->left, val, depth==2?1:depth-1);
    25. root->right = addOneRow(root->right, val, depth==2?0:depth-1);
    26. }
    27. return root;
    28. }
    29. };

  • 相关阅读:
    组件化通信
    解决编译中遇到的问题:Please port gnulib freadahead.c to your platform
    Python flask使用ajax上传文件
    ElementUI增删改的实现及表单验证
    3.3、Linux项目自动化构建工具make/makefile
    2023NOIP A层联测6 数点
    浅谈虚树(虚仙人掌)
    AI算法工程师的寒冬?我们完全可以反向思维。。。
    Linux内核mmap内存映射详解及例子实现
    Chap12.1圆通荣达,进退自如
  • 原文地址:https://blog.csdn.net/DK_Sorhic/article/details/126172509