二叉树part03(二)

  1. 平衡二叉树
cpp 复制代码
    int postorder(TreeNode* root) {
        if (root == NULL) return 0;

        int l = postorder(root->left);
        if (l == -1) return -1; // 只要出现-1 左子树中某个子树不是平衡二叉树,直接返回-1

        int r = postorder(root->right);
        if (r == -1) return -1;// 道理同上
        
        if (abs(l - r) > 1) return -1; // 尽管左右子树都是完全二叉树,两颗子树高度差>1 说明整颗树不是平衡二叉树

        int height = 1 + max(l,r);
        return height; // 否则返回最大高度
    }

    bool isBalanced(TreeNode* root) {
        if (postorder(root) == -1) return false;
        return true;
    }

257.二叉树的所有路径

cpp 复制代码
    vector<string> res;
    // 从根节点寻找所有路径,肯定是前序遍历,注意要保持字符串的输出格式
    void dfs(TreeNode* root, string s) {
        s += to_string(root->val);// 
        if (root->left == NULL && root->right == NULL) {
            res.push_back(s);
            return;
        }
        if (root -> left) dfs(root->left, s + "->"); 
        if (root -> right) dfs(root->right, s + "->");
        return;
    }

    vector<string> binaryTreePaths(TreeNode* root) { 
        res.clear();
        if (root == NULL) return res;
        string s;
        dfs(root, s);
        return res;
    }
  1. 二叉树的左叶子之和

看到本题可能一下想到层序遍历,其实没有那么简单,因为找的是左叶子不是左侧节点, 使用递归的话后序最好

cpp 复制代码
    // 后序方便一些
    int res = 0;
    void dfs(TreeNode* root) {
        // 看有无左儿子
        if (root->left) {
            // 判断左儿子是不是叶子
            if (root->left->left == NULL && root->left->right == NULL) {
                res += root->left->val;
                // 不是叶子就向下找
            }else dfs(root->left);
        } 
        // 右儿子直接向下找
        if (root->right) {
            dfs (root->right);
        }
        return;
    }

    int sumOfLeftLeaves(TreeNode* root) {
        // 节点数大于等于1
        if (root -> left == NULL && root->right == NULL) return res; // 节点数等于1和为0

        dfs(root);
        return res;
    }
相关推荐
罗西的思考7 分钟前
【OpenClaw】通过 Nanobot 源码学习架构---(5)Context
人工智能·算法·机器学习
Liudef0643 分钟前
后量子密码学(PQC)深度解析:算法原理、标准进展与软件开发行业的影响
算法·密码学·量子计算
OYpBNTQXi2 小时前
SEAL全同态加密CKKS方案入门详解
算法·机器学习·同态加密
yuannl103 小时前
数据结构----队列的实现
数据结构
蚂蚁数据AntData3 小时前
破解AI“机器味“困境:HeartBench评测实践详解
大数据·人工智能·算法·机器学习·语言模型·开源
ZC跨境爬虫3 小时前
Python异步IO详解:原理、应用场景与实战指南(高并发爬虫首选)
爬虫·python·算法·自动化
Mr_Xuhhh3 小时前
从ArrayList到LinkedList:理解链表,掌握Java集合的另一种选择
java·数据结构·链表
倦王3 小时前
力扣日刷47-补
python·算法·leetcode
沉鱼.443 小时前
第十三届题目
c语言·c++·算法
ZHOU_WUYI3 小时前
ppo算法简单实现
人工智能·pytorch·算法