我是靠谱客的博主 俏皮外套,这篇文章主要介绍力扣617. 合并二叉树 C++C++,现在分享给大家,希望可以做个参考。

给定两个二叉树,想象当你将它们中的一个覆盖到另一个上时,两个二叉树的一些节点便会重叠。

你需要将他们合并为一个新的二叉树。合并的规则是如果两个节点重叠,那么将他们的值相加作为节点合并后的新值,否则不为 NULL 的节点将直接作为新二叉树的节点。

示例 1:

输入: 
	Tree 1                     Tree 2                  
          1                         2                             
         /                        /                             
        3   2                     1   3                        
       /                                                    
      5                             4   7                  
输出: 
合并后的树:
	     3
	    / 
	   4   5
	  /     
	 5   4   7
注意: 合并必须从两个树的根节点开始。

C++

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    TreeNode* mergeTrees(TreeNode* t1, TreeNode* t2) {
        if(t1 == nullptr){
            return t2;
        }
        if(t2 == nullptr){
            return t1;
        }
        auto merge = new TreeNode(t1 -> val + t2 -> val);
        merge -> left = mergeTrees(t1 -> left, t2 -> left);
        merge -> right = mergeTrees(t1 -> right, t2 -> right);
        return merge;
    }
};

最后

以上就是俏皮外套最近收集整理的关于力扣617. 合并二叉树 C++C++的全部内容,更多相关力扣617.内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(77)

评论列表共有 0 条评论

立即
投稿
返回
顶部