给你二叉树的根结点 root ,此外树的每个结点的值要么是 0 ,要么是 1 。
返回移除了所有不包含 1 的子树的原二叉树。
节点 node 的子树为 node 本身加上所有 node 的后代。

输入:root = [1,null,0,0,1]
输出:[1,null,0,null,1]
解释:
只有红色节点满足条件“所有不包含 1 的子树”。 右图为返回的答案。

输入:root = [1,0,1,0,0,0,1]
输出:[1,null,1,null,1]

输入:root = [1,1,0,1,1,0,1,0]
输出:[1,1,0,1,1,null,1]
树中节点的数目在范围 [1, 200] 内
Node.val 为 0 或 1
源:力扣(LeetCode)
链接:https://leetcode.cn/problems/binary-tree-pruning
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
递归删除根节点。
1.判断是否删除该节点的条件是3个:
(1)自身是否为0
(2)左子节点是否可以删除,递归
(3)右子节点是否可以删除,递归
2.使用“或”融合步骤1中的三个条件,作为当前节点是否要删除
3.根节点判断是否删除或者保留
- /**
- * Definition for a binary tree node.
- * struct TreeNode {
- * int val;
- * TreeNode *left;
- * TreeNode *right;
- * TreeNode() : val(0), left(nullptr), right(nullptr) {}
- * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
- * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
- * };
- */
- class Solution {
- public:
- bool dfsDel(TreeNode* node){
- //递归终止条件
- if(node == NULL){
- return false;
- }
-
- //自身节点判断条件
- bool bs;
- if(node->val == 0){
- bs = false;
- }else{
- bs = true;
- }
-
- //左子节点和右子节点判断条件
- bool bl = dfsDel(node->left);
- bool br = dfsDel(node->right);
-
- //删左子节点
- if(bl == false){
- node->left = NULL;
- }
-
- //删右子节点
- if(br == false){
- node->right = NULL;
- }
-
- //返回最终判断条件
- return bs||bl||br;
- }
-
- TreeNode* pruneTree(TreeNode* root) {
- bool res = dfsDel(root);
- if(res)
- return root;
- else
- return NULL;
- }
- };