• Leetcode 623. 在二叉树中增加一行


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

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

    加法规则如下:

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


    在这里插入图片描述
    输入: root = [4,2,6,3,1,5], val = 1, depth = 2
    输出: [4,1,1,2,null,null,6,3,1,5]


    在这里插入图片描述
    输入: root = [4,2,null,3,1], val = 1, depth = 3
    输出: [4,2,null,1,1,3,null,null,1]


    【思路】:
    通过先序遍历,找到待插入位置的前一个节点进行操作即可。

    【代码】:

    /**
     * Definition for a binary tree node.
     * function TreeNode(val, left, right) {
     *     this.val = (val===undefined ? 0 : val)
     *     this.left = (left===undefined ? null : left)
     *     this.right = (right===undefined ? null : right)
     * }
     */
    /**
     * @param {TreeNode} root
     * @param {number} val
     * @param {number} depth
     * @return {TreeNode}
     */
    
    var preOrder = function(node, currentlevel, targetLevel, val){
        if(node != null){
            if(currentlevel == targetLevel){
                //添加节点。
                var tempNode1 = new TreeNode(val); 
                var tempNode2 = new TreeNode(val); 
                tempNode1.left = node.left;
                tempNode1.right = null;     //
                tempNode2.left = null;
                tempNode2.right = node.right;
                node.left = tempNode1;
                node.right = tempNode2;
                console.log(node.left.val);
                console.log(node.right.val);
                return ;    //后面的层次就没有必要搜索了,直接返回
            }
            preOrder(node.left, currentlevel + 1, targetLevel, val);
            preOrder(node.right, currentlevel + 1, targetLevel, val);
        }
    }
    
    var addOneRow = function(root, val, depth) {
        //depth = 1时,特殊情况。
        if(depth == 1){
            var tempNode = new TreeNode(val);
            tempNode.left = root;
            return tempNode;
        }
        preOrder(root, 1, depth - 1, val);
        return root;
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
  • 相关阅读:
    QT设计器中设计信号和槽的方法
    小样本学习在文心ERNIE3.0多分类任务应用--提示学习
    【Python基础入门3】转义字符和原字符
    CentOS 初步测试 两台虚拟机 能否连通(ping 通)
    Python源码剖析3-列表对象PyListObject
    【C++】C++基础知识(八)---结构体
    Shell | yum和rpm的使用
    Mac 使用 vscode 写 latex
    什么是HTTP状态码?常见的HTTP状态码有哪些?
    如何编写测试用例?
  • 原文地址:https://blog.csdn.net/weixin_40163242/article/details/126233417