2020年5月19日
摘要: 题目: 路径总和:给定一个二叉树和一个目标和,判断该树中是否存在根节点到叶子节点的路径,这条路径上所有节点值相加等于目标和。 说明: 叶子节点是指没有子节点的节点。 示例: 给定如下二叉树,以及目标和 sum = 22, 5 / \ 4 8 / / \ 11 13 4 / \ \ 7 2 1返回 t 阅读全文
posted @ 2020-05-19 12:42 桌子哥 阅读(822) 评论(0) 推荐(0) 编辑
摘要: 题目: 翻转二叉树:翻转一棵二叉树。 示例: 输入: 4 / \ 2 7 / \ / \1 3 6 9输出: 4 / \ 7 2 / \ / \9 6 3 1备注:这个问题是受到 Max Howell 的 原问题 启发的 : 谷歌:我们90%的工程师使用您编写的软件(Homebrew),但是您却无法 阅读全文
posted @ 2020-05-19 10:32 桌子哥 阅读(213) 评论(0) 推荐(0) 编辑
摘要: 题目: 将有序数组转换为二叉搜索树:将一个按照升序排列的有序数组,转换为一棵高度平衡二叉搜索树。 本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1。 思路: 因为输入是递增的数组,为了转换成二叉搜索树,因此需要找到整个树的根节点,之后使用递归来的得到每个子树 阅读全文
posted @ 2020-05-19 10:21 桌子哥 阅读(322) 评论(0) 推荐(0) 编辑
摘要: 题目: 二叉树的最大深度:给定一个二叉树,找出其最大深度。 二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。 说明: 叶子节点是指没有子节点的节点。 思路: 借助层序遍历来做,有多少层树就有多深。 程序: # Definition for a binary tree node. # clas 阅读全文
posted @ 2020-05-19 10:07 桌子哥 阅读(617) 评论(0) 推荐(0) 编辑
摘要: 题目: 二叉树的层次遍历 II:给定一个二叉树,返回其节点值自底向上的层次遍历。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历) 思路: 正常层序遍历结果的逆输出。 程序: # Definition for a binary tree node. # class TreeNode: # 阅读全文
posted @ 2020-05-19 09:57 桌子哥 阅读(527) 评论(0) 推荐(0) 编辑
摘要: 题目: 二叉树的层序遍历:给你一个二叉树,请你返回其按 层序遍历 得到的节点值。 (即逐层地,从左到右访问所有节点)。 思路: 层序遍历的常用解题思路。 程序: # Definition for a binary tree node. # class TreeNode: # def __init__ 阅读全文
posted @ 2020-05-19 09:35 桌子哥 阅读(1076) 评论(0) 推荐(0) 编辑
摘要: 题目: 对称二叉树:给定一个二叉树,检查它是否是镜像对称的。 例如,二叉树 [1,2,2,3,4,4,3] 是对称的。 1 / \ 2 2 / \ / \3 4 4 3 但是下面这个 [1,2,2,null,3,null,3] 则不是镜像对称的: 1 / \ 2 2 \ \ 3 3 思路: 递归大法 阅读全文
posted @ 2020-05-19 09:23 桌子哥 阅读(644) 评论(0) 推荐(0) 编辑