当前位置: 首页 > news >正文

诚信快捷小企业网站建设seo岗位职责

诚信快捷小企业网站建设,seo岗位职责,中国网站优化哪家好,图片设计美工TOC 前言 代码随想录算法训练营day17 一、Leetcode 110.平衡二叉树 1.题目 给定一个二叉树,判断它是否是高度平衡的二叉树。 本题中,一棵高度平衡二叉树定义为: 一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1 。 示例 1&#x…

@TOC


前言

代码随想录算法训练营day17


一、Leetcode 110.平衡二叉树

1.题目

给定一个二叉树,判断它是否是高度平衡的二叉树。

本题中,一棵高度平衡二叉树定义为:

一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1 。

示例 1:

输入:root = [3,9,20,null,null,15,7] 输出:true

示例 2:

输入:root = [1,2,2,3,3,null,null,4,4] 输出:false

示例 3:

输入:root = [] 输出:true

提示:

树中的节点数在范围 [0, 5000] 内
-104 <= Node.val <= 104

来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/balanced-binary-tree

2.解题思路

解题思路

方法一:自顶向下的递归

定义函数 heightheight,用于计算二叉树中的任意一个节点 pp 的高度:

height(p)={0p 是空节点max⁡(height(p.left),height(p.right))+1p 是非空节点height(p)={0max(height(p.left),height(p.right))+1​p 是空节点p 是非空节点​

有了计算节点高度的函数,即可判断二叉树是否平衡。具体做法类似于二叉树的前序遍历,即对于当前遍历到的节点,首先计算左右子树的高度,如果左右子树的高度差是否不超过 11,再分别递归地遍历左右子节点,并判断左子树和右子树是否平衡。这是一个自顶向下的递归的过程。

3.代码实现

```java class Solution { public boolean isBalanced(TreeNode root) { if (root == null) { return true; } else { return Math.abs(height(root.left) - height(root.right)) <= 1 && isBalanced(root.left) && isBalanced(root.right); } }

public int height(TreeNode root) {if (root == null) {return 0;} else {return Math.max(height(root.left), height(root.right)) + 1;}
}

}

```

二、Leetcode 257. 二叉树的所有路径

1.题目

给你一个二叉树的根节点 root ,按 任意顺序 ,返回所有从根节点到叶子节点的路径。

叶子节点 是指没有子节点的节点。

示例 1:

输入:root = [1,2,3,null,5] 输出:["1->2->5","1->3"]

示例 2:

输入:root = [1] 输出:["1"]

提示:

树中节点的数目在范围 [1, 100] 内
-100 <= Node.val <= 100

来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/binary-tree-paths

2.解题思路

方法一:深度优先搜索

思路与算法

最直观的方法是使用深度优先搜索。在深度优先搜索遍历二叉树时,我们需要考虑当前的节点以及它的孩子节点。

如果当前节点不是叶子节点,则在当前的路径末尾添加该节点,并继续递归遍历该节点的每一个孩子节点。
如果当前节点是叶子节点,则在当前路径末尾添加该节点后我们就得到了一条从根节点到叶子节点的路径,将该路径加入到答案即可。

如此,当遍历完整棵二叉树以后我们就得到了所有从根节点到叶子节点的路径。当然,深度优先搜索也可以使用非递归的方式实现,这里不再赘述。

3.代码实现

```java class Solution { public List binaryTreePaths(TreeNode root) { List paths = new ArrayList(); constructPaths(root, "", paths); return paths; }

public void constructPaths(TreeNode root, String path, List<String> paths) {if (root != null) {StringBuffer pathSB = new StringBuffer(path);pathSB.append(Integer.toString(root.val));if (root.left == null && root.right == null) {  // 当前节点是叶子节点paths.add(pathSB.toString());  // 把路径加入到答案中} else {pathSB.append("->");  // 当前节点不是叶子节点,继续递归遍历constructPaths(root.left, pathSB.toString(), paths);constructPaths(root.right, pathSB.toString(), paths);}}
}

}

```

三、Leetcode 404.左叶子之和 v

1.题目

给定二叉树的根节点 root ,返回所有左叶子之和。

示例 1:

输入: root = [3,9,20,null,null,15,7] 输出: 24 解释: 在这个二叉树中,有两个左叶子,分别是 9 和 15,所以返回 24

示例 2:

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

提示:

节点数在 [1, 1000] 范围内
-1000 <= Node.val <= 1000

来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/sum-of-left-leaves

2.解题思路

方法一:深度优先搜索

3.代码实现

```java class Solution { public int sumOfLeftLeaves(TreeNode root) { return root != null ? dfs(root) : 0; }

public int dfs(TreeNode node) {int ans = 0;if (node.left != null) {ans += isLeafNode(node.left) ? node.left.val : dfs(node.left);}if (node.right != null && !isLeafNode(node.right)) {ans += dfs(node.right);}return ans;
}public boolean isLeafNode(TreeNode node) {return node.left == null && node.right == null;
}

}

```

http://www.ritt.cn/news/3712.html

相关文章:

  • 做网站的前景谷歌搜索入口
  • 顺德做营销网站公司佛山百度推广公司
  • 成都疫情最新消息发布seo搜索引擎优化推荐
  • 优畅 wordpress南昌百度搜索排名优化
  • 高中信息技术课程做网站做网站推广的公司
  • 网站建设与运营公司财务预算百度推广的方式
  • t恤定制网站最有效的网络推广方式
  • asp动态网站开发基础教程答案百度推广好不好做
  • 个性网站建设福州百度关键词优化
  • 网页模板的使用方法黄山seo推广
  • 广东基层团组织建设部网站怎么在百度上面打广告
  • 美食怎么做的小视频网站seo优化思路
  • 可做产品预售的网站网络营销的5种营销方式
  • 怎么自己做网站服务器linux百度seo正规优化
  • 制作动态网站用什么软件深圳网络推广公司哪家好
  • 做外贸主要在那些网站找单深圳营销型网站设计公司
  • 专门做图标的网站网站模板哪里好
  • 专门做音乐的网站搜索引擎优化特点
  • 阜宁做网站的公司网络优化工程师主要负责什么工作
  • 网站如何做内链个人免费域名注册网站
  • 用vs2010里的vb做网站seo网络培训班
  • 英语网站建设宁波网站seo诊断工具
  • 曰本孕妇做爰网站个人网页制作教程
  • wordpress怎么做企业网站信息流优化师简历模板
  • 互联网定制网站热点军事新闻
  • 徐州建站seo教学免费课程霸屏
  • 网站建设要准备什么百度小说搜索风云榜排名
  • 个人网站备案 服务内容怎么写百度推广客户端怎么登陆
  • 美观网站建设物美价廉seo关键词优化价格
  • 做网站首页ps中得多大百度快照客服电话