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

lol小米和谁做的视频网站响应 网站建设

lol小米和谁做的视频网站,响应 网站建设,阿里巴巴吧网站建设,中铁建设集团门户员工登录题目 中等 给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。 叶子节点 是指没有子节点的节点。 示例 1: 输入:root [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSu…

题目

中等

给你二叉树的根节点 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

面试中遇到过这道题?

1/5

通过次数

407.3K

提交次数

644.1K

通过率

63.2%

思路:

这个和第112题一样,只不过我们现在要返回所有满足条件的路径,而不是判断是否满足条件。和上一题一样的方法,只不过是在维护路径和的同时,记录路径。

方法一:深度优先搜索

class Solution {
public:void dfs(vector<vector<int>> &ans,vector<int> &path,TreeNode* root,int sum,int targetSum){if(!root) return;else if(!root->left&&!root->right){path.push_back(root->val);if(sum+root->val==targetSum)ans.push_back(path);}else{path.push_back(root->val);if(root->left){dfs(ans,path,root->left,sum+root->val,targetSum);path.pop_back();}if(root->right){dfs(ans,path,root->right,sum+root->val,targetSum);path.pop_back();}}}vector<vector<int>> pathSum(TreeNode* root, int targetSum) {vector<int> path;vector<vector<int>> ans;dfs(ans,path,root,0,targetSum);return ans;}
};

方法二:广度优先搜索

和判断是否存在路径和等于目标的方法一样,要多注意的点就是,为了方便记录路径,设置一个哈希表,记录每个非根节点的父亲节点。这样每次找到一条符合条件的路径,就从叶子节点开始往上找,记录路径。

下面是官解

class Solution {
public:vector<vector<int>> ret;unordered_map<TreeNode*, TreeNode*> parent;void getPath(TreeNode* node) {vector<int> tmp;while (node != nullptr) {tmp.emplace_back(node->val);node = parent[node];}reverse(tmp.begin(), tmp.end());ret.emplace_back(tmp);}vector<vector<int>> pathSum(TreeNode* root, int targetSum) {if (root == nullptr) {return ret;}queue<TreeNode*> que_node;queue<int> que_sum;que_node.emplace(root);que_sum.emplace(0);while (!que_node.empty()) {TreeNode* node = que_node.front();que_node.pop();int rec = que_sum.front() + node->val;que_sum.pop();if (node->left == nullptr && node->right == nullptr) {if (rec == targetSum) {getPath(node);}} else {if (node->left != nullptr) {parent[node->left] = node;que_node.emplace(node->left);que_sum.emplace(rec);}if (node->right != nullptr) {parent[node->right] = node;que_node.emplace(node->right);que_sum.emplace(rec);}}}return ret;}
};

http://www.yayakq.cn/news/349581/

相关文章:

  • 宜春市城乡规划建设局网站做网站的竞品分析
  • 免费做片头的网站邯郸做企业网站改版
  • 绿色企业网站模板wordpress微博登陆插件
  • 装饰行业模板网站龙岩网红街
  • 如何不花钱开发网站网站怎么做留言提交功能
  • 西安道桥建设有限公司网站厦门市建设局思明建设分局官方网站
  • 网站建设教程搭建浊贝湖南岚鸿给力专门做照片书的网站
  • 宁波中科网站建设有限公司网络营销公司哪家好
  • 上海大规模网站建设平台汉服网页设计素材
  • 快速做网站企业通用网站模板
  • 珠海营销营网站建设公司安卓软件是哪个公司开发的
  • 微信分销网站建设多少钱莱芜杂谈 莱芜话题
  • 南京需要做网站的公司网站开发工程师asp考试
  • 设计网站要包含信息类型网站开发语言对比
  • 东莞微信网站建设动态酒店类网站开发的策略
  • 中国风html5网站模板免费下载朝阳开发公司
  • o基础学建网站网站制作怎样做背景
  • 开发网站实训的心得体会手机短视频制作软件app
  • 网站如何做服务器授权书江苏省建设考试网站准考证打印
  • 正规的编程培训机构关键词整站优化公司
  • 北京公司响应式网站建设价位上海建设网站费用
  • php开源企业网站重庆市住房和城乡建设部网站
  • 晋城市住房和城乡建设局官方网站花生壳免费域名注册
  • 济南网站开发推广旅行网站排名前十名
  • 深圳市南山区住房和建设局官方网站中国小康建设网 是个什么网站
  • 怎么查看网站是asp还是php深圳建一个网站要多少钱
  • 如何给网站加关键词鞋业有限公司网站设计
  • 怎么做淘客网站要屏蔽一个网站要怎么做
  • 不良网站浏览窗口ios开发者账号续费
  • 如何把网站的文字编辑地方门户网站运营