代码随想录day17|平衡二叉树、二叉树的所有路径、左叶子之和

平衡二叉树

这道题需要我们求解的是高度平衡,所以我们应该使用后序遍历的方法来求解本题。首先我们确定递归函数的传入参数和返回值,传入参数是每个节点,返回值是以每个节点为根节点树的高度。其次我们确定中止条件,终止条件就是节点为空,那么结果返回的树的结果就是0。接下来我们确定单层递归的逻辑,在这时候我们需要确定以一个节点为根节点的树都有两种结果,一个是返回的它的高度,另一个是返回-1,说明不是一个平衡二叉树。

class Solution {
public:
    int getHeight(TreeNode* node)
    {
        if(node == NULL) return 0;
        int leftHeight = getHeight(node->left);//leftHeight是以当前节点的左节点为根节点的树的高度
        if(leftHeight == -1) return -1;
        int rightHeight = getHeight(node->right);//rightHeight是以当前节点的右节点为根节点的树的高度
        if(rightHeight == -1) return -1;
        if(abs(rightHeight - leftHeight) > 1) return -1;//如果当前节点左右子树的高度差大于1,那么结果就返回-1,说明这个树不是一个平衡二叉树。
        return 1 + max(rightHeight,leftHeight);//否则他是一个平衡二叉树,返回的结果是以这个节点为根节点的树的高度。
    }
    bool isBalanced(TreeNode* root) {
        return getHeight(root) == -1 ? false : true;
    }

二叉树的所有路径

这道题后续还是需要好好加深理解。还有c++11的知识需要进行补充了。

class Solution {
public:
    //得到传入节点的所有路径,以根节点为例子,就是的得到1->2->3和1->3
    void traversal(TreeNode* node,vector<int>& path,vector<string>& result)
    {
        path.push_back(node->val);//这一步需要放在中止条件之上,如果放在中止条件之下,例如traversal 3的时候,3左右子节点都为空,就直接返回result了,就没有加入3进去。
        if(node->left == NULL && node->right == NULL){
            string sPath;
            for(int i = 0;i < path.size() - 1;i++)
            {
                sPath += to_string(path[i]);
                sPath += "->";
            }
            sPath += to_string(path[path.size() - 1]);
            result.push_back(sPath);
            return;
        }
        //以根节点为例,traversal得到就是2->5
        if(node->left) 
        {
            traversal(node->left,path,result);
            path.pop_back();//弹出2
        }
        //根节点的右节点3存在,traversal得到的就是3
        if(node->right) 
        {
            traversal(node->right,path,result);
            path.pop_back();//弹出3
        }
    }
    vector<string> binaryTreePaths(TreeNode* root) {
        vector<int> path;
        vector<string> result;
        if(root == NULL) return result;
        traversal(root,path,result);
        return result;
    }
};

左叶子之和

这道题的要返回所有的叶子之和,具体思路是我们收集根节点的左子树的左叶子和右子树的左叶子,这样我们就能收集到这颗二叉树的所有左叶子之和。在收集根节点的左叶子之和过程中,我们难免会进入一个节点去收集其左子树的左叶子,收集其右子树的左叶子,这样的就是基本的递归思想。

class Solution {
public:
    int sumLeftLeaves(TreeNode* node)//节点的左叶子之和
    {
        if(node == NULL) return 0;
        if(!node->left && !node->right) return 0;
        int leftValue = sumLeftLeaves(node->left);//左节点的左叶子之和
        if(node->left && !node->left->right && !node->left->left){
            leftValue = node->left->val;
        }
        int rightValue = sumLeftLeaves(node->right);//右节点的左叶子之和
        int sum = leftValue + rightValue;
        return sum;
    }
    int sumOfLeftLeaves(TreeNode* root) {
        return sumLeftLeaves(root);
    }
};

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值