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

做网站论坛赚钱营销推广计划

做网站论坛赚钱,营销推广计划,武汉网站优化推广价格,下沙做网站的公司题目 中等 给你二叉树的根节点 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.ds6.com.cn/news/72355.html

相关文章:

  • 淄博政府网站建设托管河北网站seo外包
  • 禹城有做网站班级优化大师的优点
  • 网站权重数据包360网站推广费用
  • wordpress 4.3北京优化seo排名
  • 霸州有做滤芯网站的吗优化推广联盟
  • 重庆微网站开发公司深圳网络推广有几种方法
  • 集团网站建设方案百度关键词挖掘工具爱站网
  • 网站文件夹结构百度官网推广
  • avada主题做网站竞价推广开户电话
  • 芜湖营销网站建设新闻头条国内大事
  • 莱芜营销型网站制作长沙关键词优化首选
  • 长沙正规网站建设价格seo诊断分析报告
  • 网站备案对应的ip地址优化大师软件下载
  • wnmp搭建后怎么做网站上海网络营销有限公司
  • 广州建论坛网站建网站用什么软件
  • 做瞹瞹嗳视频网站在线观看百度建站平台官网
  • 十个app制作网站电子商务营销策略有哪些
  • 单页网站制作系统有道搜索引擎入口
  • 网站策划招聘网络营销与网站推广的区别
  • 国外做logo的网站优化防控举措
  • 视频教学互动网站建设市场推广方案怎么做
  • 中企动力做的网站山西太原专业搜索引擎优化电话
  • 哈尔滨建筑工程招聘信息seo价格查询公司
  • 网站建设方案备案免费域名注册
  • 网站建设数据库是什么意思推广代理平台登录
  • 门户类网站的主页设计免费网站怎么做出来的
  • 公司网站建设总结怎么在网络上推广
  • 做网站需要许可证吗网络推广软文范文
  • 微信授权登录第三方网站开发优化关键词技巧
  • 做别人的网站诈骗视频下载广东深圳疫情最新