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

leetcode0113. 路径总和 II - medium

1 题目:路径总和 II

官方标定难度:中

给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。

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

示例 1:

在这里插入图片描述

输入:root = [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSum = 22
输出:[[5,4,11,2],[5,8,4,5]]

示例 2:

在这里插入图片描述

输入:root = [1,2,3], targetSum = 5
输出:[]

示例 3:

输入:root = [1,2], targetSum = 0
输出:[]

提示:

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

2 solution

和 112 题差不多,只不过需要保存路径,只需要,在每一步时,将当前节点加入到路径中,如果找到一个答案,就保存下来。

代码

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:
void pathSum(TreeNode *root, int targetSum, vector<vector<int>> &result,vector<int> &solution) {if (!root->left && !root->right) {if (targetSum == root->val) {solution.push_back(root->val);result.push_back(solution);solution.pop_back();}return;}solution.push_back(root->val);targetSum -= root->val;if (root->left) pathSum(root->left, targetSum, result,solution);if (root->right) pathSum(root->right, targetSum, result,solution);solution.pop_back();
}vector<vector<int>> pathSum(TreeNode *root, int targetSum) {if (!root) return {};vector<vector<int>> result;vector<int> solution;pathSum(root, targetSum, result,solution);return result;
}};

结果

在这里插入图片描述

相关文章:

  • 6.8 Python定时任务实战:APScheduler+Cron实现每日/每周自动化调度
  • 重读《人件》Peopleware -(7)Ⅰ管理人力资源Ⅵ-莱特瑞尔 Laetrile
  • 3. 在 2节的基础上 ,实现launch文件简单编写
  • 遨游科普:防爆平板是指什么?有哪些应用场景?
  • 【EDA软件】【设计约束和分析操作方法】
  • ai学习中收藏网址【1】
  • Python学习之Seaborn
  • Redis 的持久化机制(RDB, AOF)对微服务的数据一致性和恢复性有何影响?如何选择?
  • CiteULike 数据集介绍与下载指南
  • docker底层原理
  • 使用Redis5.X部署一个集群
  • FPGA——基于DE2_115实现DDS信号发生器
  • 2024期刊综述论文 Knowledge Graphs and Semantic Web Tools in Cyber Threat Intelligence
  • 2025.04.19【Spider】| 蜘蛛图绘制技巧精解
  • TDOA解算——牛顿迭代法|以4个基站的三维空间下TDOA定位为背景,使用牛顿迭代法解算。附完整代码,订阅专栏后可复制粘贴
  • XSS跨站脚本攻击漏洞
  • 哈希表简介
  • 1. 认识DartGoogle为Flutter选择了Dart语言已经是既
  • 行为审计软件:企业合规与内部监控的数字守门人
  • Spring AI 开发 - 快速入门
  • 小米回应SU7Ultra排位模式限制车辆动力:暂停推送更新
  • 60岁济南石化设计院党总支书记、应急管理专家李有臣病逝
  • 巴基斯坦宣布关闭全国空域48小时
  • 山东滕州一车辆撞向公交站台致多人倒地,肇事者被控制,案件已移交刑警
  • 探访小剧场、直播间、夜经济:五一假期多地主官调研新消费
  • 贵州游船侧翻248名消防员已在搜救