代码随想录算法训练营第十七天|LeetCode110 平衡二叉树、LeetCode257 二叉树的所有路径

题1:

指路:LeetCode110 平衡二叉树
思路与代码:

左右子树的高度差小于等于1。对于这个题,递归比迭代方便太多,我也想过迭代,但是我没有写出来,大家可以自己试一下。递归代码如下:

cpp 复制代码
class Solution {
public:
    //递归
    int getHeight  (TreeNode* node) {
        if (node == NULL) {return 0;}
        int leftHeight = getHeight(node->left);
        if (leftHeight == -1) return -1;
        int rightHeight = getHeight(node->right);
        if (rightHeight == -1) return -1;
        int ans = abs(leftHeight - rightHeight);
        if (ans > 1) return -1;  // 绝对值超过1符合条件
        else return 1 + max(leftHeight, rightHeight);
       /* return abs(leftHeight - rightHeight) > 1 ? -1 : 1 + max(leftHeight, rightHeight);*/
    } 
    bool isBalanced(TreeNode* root) {
    if (getHeight(root)== -1) 
    return false;
    return true;
    /*return getHeight(root) == -1 ? false : true;*/
    }
};

题2:

指路:LeetCode257 二叉树的所有路径
思路与代码:

递归进行前序遍历,找到子节点记录路径之后回溯回退路径。我还没会呢,先看看代码吧。

cpp 复制代码
class Solution {
private:
    void treversal(TreeNode* cur, vector<int>& path, vector<string>& result) {
        path.push_back(cur->val);
        if (cur->left == NULL && cur->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 ;
        }
        if (cur->left) {
            treversal(cur->left, path, result);
            path.pop_back();
        }
        if (cur->right) {
            treversal(cur->right, path, result);
            path.pop_back();
        }
    }
    public:
    vector<string> binaryTreePaths(TreeNode* root) {
    vector<string> result;
    vector<int> path;
    if (root == NULL) return result;
    treversal(root, path, result);
    return result;
    }
};
相关推荐
阿捏利3 小时前
C++ Primer Plus 第六版 第二章 编程题
c++·编程题·c++ primer plus
何妨重温wdys6 小时前
贪心算法解决钱币找零问题(二)
算法·贪心算法
007php0076 小时前
Go 面试题: new 和 make 是什么,差异在哪?
后端·算法·docker·容器·面试·职场和发展·golang
一支鱼6 小时前
leetcode-3-无重复字符的最长子串
算法·leetcode·typescript
卡尔曼的BD SLAMer8 小时前
计算机视觉与深度学习 | 传统图像处理技术的未来发展前景分析
图像处理·算法·计算机视觉
星期天要睡觉8 小时前
(纯新手教学)计算机视觉(opencv)实战十一——轮廓近似(cv2.approxPolyDP)
opencv·算法·计算机视觉
软糖工程0018 小时前
python中的分代垃圾回收机制的原理【python进阶二、2】
python·算法
郝学胜-神的一滴9 小时前
Pomian语言处理器研发笔记(二):使用组合模式定义表示程序结构的语法树
开发语言·c++·笔记·程序人生·决策树·设计模式·组合模式
玉木子9 小时前
机器学习(四)KNN算法-分类
算法·机器学习·分类
青瓦梦滋9 小时前
Linux基本工具(yum、vim、gcc、Makefile、git、gdb)
linux·运维·服务器·c++