热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

LeetCode——1302.层数最深叶子节点的和

题目描述:给你一棵二叉树的根节点root,请你返回层数最深的叶子节点的和。示例1:输入:root[1,2,3,4,5,n

题目描述:

给你一棵二叉树的根节点 root ,请你返回层数最深的叶子节点的和 。

示例 1:

在这里插入图片描述

输入:root = [1,2,3,4,5,null,6,7,null,null,null,null,8]
输出:15
示例 2:

输入:root = [6,7,8,2,7,1,3,9,null,1,4,null,null,null,5]
输出:19

提示:

  • 树中节点数目在范围 [1, 104] 之间。
  • 1 <&#61; Node.val <&#61; 100

dfs代码如下&#xff1a;

/*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(int val) { this.val &#61; val; }* TreeNode(int val, TreeNode left, TreeNode right) {* this.val &#61; val;* this.left &#61; left;* this.right &#61; right;* }* }*/
class Solution {public int sum &#61; 0;public int deepestLeavesSum(TreeNode root) {int maxDepth &#61; depth(root);dfs(root, 1, maxDepth);return sum;}public void dfs(TreeNode root, int depth, int maxDepth) {if (root &#61;&#61; null) {return;}if (depth &#61;&#61; maxDepth) {sum &#43;&#61; root.val;}dfs(root.left, depth &#43; 1, maxDepth);dfs(root.right, depth &#43; 1, maxDepth);}public int depth(TreeNode root) {if (root &#61;&#61; null) {return 0;}return Math.max(depth(root.left), depth(root.right)) &#43; 1;}
}

bfs代码如下&#xff1a;

/*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(int val) { this.val &#61; val; }* TreeNode(int val, TreeNode left, TreeNode right) {* this.val &#61; val;* this.left &#61; left;* this.right &#61; right;* }* }*/
class Solution {public int deepestLeavesSum(TreeNode root) {if (root &#61;&#61; null) {return 0;}Queue<TreeNode> que &#61; new LinkedList<>();que.offer(root);int ans &#61; 0;while (!que.isEmpty()) {List<Integer> r &#61; new ArrayList<>();int size &#61; que.size();ans &#61; 0;for (int i &#61; 0; i < size; i&#43;&#43;) {TreeNode t &#61; que.poll();ans &#43;&#61; t.val;if (t.left !&#61; null) {que.offer(t.left);}if (t.right !&#61; null) {que.offer(t.right);}}}return ans;}
}

执行结果&#xff1a;
在这里插入图片描述


推荐阅读
author-avatar
mobiledu2502875213
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有