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

leetcode练习 路径总和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]]

思路:前序遍历将每一条到底的路径存到path中并验证是否符合条件,将符合条件的路径放入res中,最终返回res。

/*** 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:vector<vector<int>>res;vector<int>path;void DFS(TreeNode * root,int targetSum){path.push_back(root->val);if(root->left==nullptr&&root->right==nullptr){int sum=0;for(int i=0;i<path.size();i++){sum+=path[i];}if(sum==targetSum){res.push_back(path);}}if(root->left){DFS(root->left,targetSum);path.pop_back();}if(root->right){DFS(root->right,targetSum);path.pop_back();}}vector<vector<int>> pathSum(TreeNode* root, int targetSum) {if(root==nullptr)return res;DFS(root,targetSum);return res;}
};

http://www.lryc.cn/news/453097.html

相关文章:

  • 使用Three.js库创建的简单WebGL应用程序,主要用于展示具有不同透明度和缩放比例的圆环列
  • Redis: 集群架构,优缺点和数据分区方式和算法
  • 负载均衡可以在网络模型的哪一层?
  • YOLOv11改进 | 上采样篇 | YOLOv11引入CARAFE上采样
  • 【Linux运维】grep命令粗浅学习
  • 【Godot4.3】匀速和匀变速直线运动粒子
  • 基于Hive和Hadoop的用电量分析系统
  • 一个简单的摄像头应用程序4
  • SpringBoot使用EasyPoi根据模板导出word or pdf
  • NVIDIA Hopper 架构深入
  • AWS IoT Core for Amazon Sidewalk
  • 今日指数项目项目集成RabbitMQ与CaffienCatch
  • C0005.Clion中移动ui文件到新目录后,报错问题的解决
  • 基于STM32的智能家居灯光控制系统设计
  • 06.useEffect
  • 【设计模式-中介者模式】
  • 树和二叉树知识点大全及相关题目练习【数据结构】
  • ajax的原理,使用场景以及如何实现
  • lock_guard和unique_lock学习总结
  • 数据挖掘-padans初步使用
  • 小阿轩yx-案例:项目发布基础
  • 【HarmonyOS】时间处理Dayjs
  • 论React Native 和 UniApp 的区别
  • 微信小程序处理交易投诉管理,支持多小程序
  • Pikachu-xss防范措施 - href输出 js输出
  • 数据结构双向链表和循环链表
  • go基础面试题汇总第一弹
  • Redis 实现分布式锁时需要考虑的问题
  • 百年极限论一直存在百年糊涂话:有正数小于所有正数
  • 红日靶场1学习笔记