zoukankan      html  css  js  c++  java
  • 375 克隆二叉树

    原题网址:https://www.lintcode.com/problem/clone-binary-tree/description

    描述

    深度复制一个二叉树。

    给定一个二叉树,返回一个他的 克隆品 。

    您在真实的面试中是否遇到过这个题?  

    样例

    给定一个二叉树:

         1
       /  
      2    3
     / 
    4   5
    

    返回其相同结构相同数值的克隆二叉树:

         1
       /  
      2    3
     / 
    4   5

    标签
    二叉树
     
    思路:创建二叉树,不用多说,递归。从根节点开始创建,然后是左孩子、右孩子。左、右孩子的子树也是相同的顺序,如此递归下去,直到所有节点拷贝创建完毕。
     
    AC代码:
    /**
     * Definition of TreeNode:
     * class TreeNode {
     * public:
     *     int val;
     *     TreeNode *left, *right;
     *     TreeNode(int val) {
     *         this->val = val;
     *         this->left = this->right = NULL;
     *     }
     * }
     */
    
    class Solution {
    public:
        /**
         * @param root: The root of binary tree
         * @return: root of new tree
         */
        TreeNode * cloneTree(TreeNode * root) {
            // write your code here
        if (root==NULL)
        {
            return root;
        }
        TreeNode *newnode=new TreeNode(root->val);
        newnode->left=cloneTree(root->left);
        newnode->right=cloneTree(root->right);
        return newnode;
        }
    };
  • 相关阅读:
    js-20170816-Date对象
    js-20170804-Math对象
    js-20170619-string对象
    微信web开发者工具
    前端开发指南
    接口调试工具DHC
    CSS预处理器
    Weex
    Vue.js
    hbuilder
  • 原文地址:https://www.cnblogs.com/Tang-tangt/p/9196445.html
Copyright © 2011-2022 走看看