我是靠谱客的博主 俏皮外套,最近开发中收集的这篇文章主要介绍力扣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. 合并二叉树 C++C++所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

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

评论列表共有 0 条评论

立即
投稿
返回
顶部