首页 > 其他 > 详细

p50 合并二叉树 (leetcode 617)

时间:2020-03-17 18:32:00      阅读:44      评论:0      收藏:0      [点我收藏+]

一:解题思路

Time:O(n),Space:O(n)

二:完整代码示例 (C++版和Java版)

C++:

class Solution {
public:
    TreeNode* mergeTrees(TreeNode* t1, TreeNode* t2) 
    {
        if (t1 == NULL && t2 == NULL) return NULL;
        if ((t1 == NULL) && (t2 != NULL)) return t2;
        if ((t1 != NULL) && (t2 == NULL)) return t1;
        
        t1->val = (t1->val+t2->val);
        t1->left = mergeTrees(t1->left,t2->left);
        t1->right = mergeTrees(t1->right,t2->right);

        return t1;
    }
};

Java:

class Solution {
    public TreeNode mergeTrees(TreeNode t1, TreeNode t2)
    {
          if((t1==null)&&(t2==null)) return null;
          if((t1==null)&&(t2!=null)) return t2;
          if((t1!=null)&&(t2==null)) return t1;
          
          t1.val=t1.val+t2.val;
          t1.left=mergeTrees(t1.left,t2.left);
          t1.right=mergeTrees(t1.right,t2.right);
          
          return t1;
    }
}

 

p50 合并二叉树 (leetcode 617)

原文:https://www.cnblogs.com/repinkply/p/12512341.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!