二叉树剪枝

1、题目解析

2、算法解析

本题使用二叉树的后序遍历,通过递归函数将左右子树进行处理,得到处理结果后,判断左右结果以及自身的val判断是否需要剪枝。

3、代码编写

cpp 复制代码
class Solution {
public:
    TreeNode* pruneTree(TreeNode* root) {

        if(root == nullptr)
        {
            return nullptr;
        }

        root->left = pruneTree(root->left);
        root->right = pruneTree(root->right);

        if(root->left == nullptr && root->right == nullptr && root->val == 0)
        {
            return nullptr;
        }

        return root;

        
    }
};
相关推荐
楚来客1 分钟前
AI基础概念之十一:CNN算法的基本原理
人工智能·算法·cnn
listhi5202 分钟前
空间机器人动力学正逆解及遗传算法路径规划(MATLAB实现)
算法·matlab·机器人
橘颂TA6 分钟前
【剑斩OFFER】算法的暴力美学——leetCode 662 题:二叉树最大宽度
c++·算法·结构与算法
zl_vslam8 分钟前
SLAM中的非线性优-3D图优化之绝对位姿SE3约束左扰动(十六)
人工智能·算法·计算机视觉·3d
a努力。8 分钟前
得物Java面试被问:B+树的分裂合并和范围查询优化
java·开发语言·后端·b树·算法·面试·职场和发展
beiguang_jy10 分钟前
线离线TOC总有机碳测试仪
大数据·人工智能·科技·算法·制造·零售·风景
yi.Ist14 分钟前
博弈论 Nim游戏
c++·学习·算法·游戏·博弈论
sali-tec25 分钟前
C# 基于OpenCv的视觉工作流-章12-双边滤波
图像处理·人工智能·opencv·算法·计算机视觉
乌萨奇也要立志学C++29 分钟前
【洛谷】分治专题 逆序对、第 k 小、最大子段和
c++·算法
sonadorje30 分钟前
逻辑回归的对数损失
算法·机器学习·逻辑回归