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

力扣面试150题--求根节点到叶节点数字之和

Day 48

题目描述

在这里插入图片描述

思路

我们利用sum这个全局变量来保存总和值,递归函数sum来计算每个根到叶子节点路径所代表的数,由于我们需要遍历到每条根到叶子节点的路径,所有我采取了前序遍历,如果不是叶子节点,就计算到该节点代表的值,就是qian*10+当前节点的值,qian的意思就是根到这个节点路径上的值(代表的数),到根节点就先获取到这个值,然后加到sum即可。

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public int sum=0;//保存总和public void sums(TreeNode root,int qian){if(root==null){return;}if(root.left==null&&root.right==null){qian=qian*10+root.val;sum+=qian;}else{qian=qian*10+root.val;}sums(root.left,qian);sums(root.right,qian);}public int sumNumbers(TreeNode root) {//就是前序遍历if(root.left==null&&root.right==null){//特殊处理根就是叶子节点return root.val;}sums(root.left,root.val);sums(root.right,root.val);return sum;}
}
http://www.xdnf.cn/news/8684.html

相关文章:

  • 如何屏蔽mac电脑更新提醒,禁止系统更新(最新有效方法)
  • 5060显卡驱动PyCUDA开发环境搭建
  • 25. 日志装饰器的开发
  • 使用 Go 语言实现完整且轻量级高性能的 MQTT Broker
  • Vue3 Composition API: 企业级应用最佳实践方案
  • SDL2常用函数:SDL_Texture 数据结构及使用介绍
  • 微信小程序数据接收
  • 数据结构---二叉树
  • 基于python的机器学习(九)—— 评估算法(二)
  • OpenLayers 开发环境搭建
  • 初识 RocketMQ 知识总结:基础概念、架构解析、核心特性与应用场景
  • 解决“uv 无法识别为命令”问题:Windows 下 Python 工具安装后的路径配置方法
  • 国际前沿知识系列五:时间序列建模方法在头部撞击运动学测量数据降噪中的应用
  • Spring Cloud Gateway 微服务网关实战指南
  • python操作MySQL数据库
  • 再论自然数全加和-4
  • laravel中模型中$fillable的用法
  • DeepSeek-R1 模型现已在亚马逊云科技上推出
  • 再谈Linux进程:进程等待、进程替换与环境变量
  • 第七章:组件之城 · 重构世界的拼图术
  • RabbitMQ 快速上手
  • 【RichTextEditor】 【分析2】RichTextEditor设置文字内容背景色
  • 第八章:数据库查询优化
  • 上升沿计数 stm32 中断
  • 用service 和 SCAN实现sqlplus/jdbc连接Oracle 11g RAC时负载均衡
  • 在Mac中使用pyenv管理Python版本:从安装到虚拟环境的全流程指南
  • 物联网网关保障沼气发电站安全运行的关键技术解析
  • 文章记单词 | 第111篇(六级)
  • 江科大ADC模数转换hal库实现
  • C++构造函数和析构函数