每周 ARTS 第 32 周

1. Algorithm

路径总和(简单)

描述:

给定一个二叉树和一个目标和,判断该树中是否存在根节点到叶子节点的路径,这条路径上所有节点值相加等于目标和。
叶子节点是指没有子节点的节点。

示例:

给定如下二叉树,以及目标和 sum = 22,
              5
             / \
            4   8
           /   / \
          11  13  4
         /  \      \
        7    2      1

思路:

从根节点开始遍历,每次遍历时从目标和减去当前节点值,当作子节点要凑的和,在叶子节点判断是否刚好凑齐。

class Sulution {
    pbulic boolean hasPathSum(TreeNode root, int sum) {
        if (root == null) {
            return false;
        }
        if (root.left == null && root.right == null) {
            return sum == root.val;
        }
        int csum = sum - root.val;
        return hasPathSum(root.left, csum) || hasPathSum(root.right, csum);
    }
}

分析:

  • 时间复杂度:O(N)
  • 空间复杂度:O(log(N)) or O(N)

2. Review

A 3-Minute Hack for Focus You’ve Probably Never Heard Of 你从未听说过的 3 分钟聚焦大法

作者一直无法专注工作,同事分享了一个方法给他——双耳节拍。本质上,双耳节拍是重复播放的音乐。它没有实际的节拍,而是在大脑中产生的同时播放两个不同频率的音调。

我一直在用的产品叫「小睡眠」,它主要功能是助眠,但是也有聚焦和放松模式。配合降噪耳机,很快便进入高效工作中。

3. Tip

接手维护老项目,开发者代码设计得烂,不知道怎么代码怎么调用,也无处安放 debug 点。这时只要创建一个异常,打印它的 stack track,就能够对调用时序一目了然。查看源码时也可以通过这种办法确定调用流程。

4. Share

CS-Notes GitHub 100k+ star 的项目,技术面试必备基础知识、Leetcode、计算机操作系统、计算机网络、系统设计、Java 等。

面试前可以刷一刷,主要是增加知识面的广度。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Algorithm 101. 对称二叉树(简单) 描述: 给定一个二叉树,检查它是否是镜像对称的。 示例: ...
    落英坠露阅读 195评论 0 0
  • 1. Algorithm 268. 缺失数字(简单) 描述: 给定一个包含 0, 1, 2, ..., n 中 n...
    落英坠露阅读 171评论 0 0
  • 1. Algorithm 62. 不同路径(中等) 描述: 一个机器人位于一个 m x n 网格的左上角 (起始点...
    落英坠露阅读 432评论 0 0
  • 1. Algorithm 226. 翻转二叉树(简单) 描述: 翻转一棵二叉树 示例: 思路: 递归法:翻转一个二...
    落英坠露阅读 180评论 0 1
  • 久违的晴天,家长会。 家长大会开好到教室时,离放学已经没多少时间了。班主任说已经安排了三个家长分享经验。 放学铃声...
    飘雪儿5阅读 7,575评论 16 22