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

如何把php做的网站做成appseo中文全称是什么

如何把php做的网站做成app,seo中文全称是什么,可以下载的网站模板,济南网站建设艮安题目 中等 给你二叉树的根节点 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/100164.html

相关文章:

  • 广安网站建设哪家好百度怎么发布自己的信息
  • 常见的导航网站有哪些品牌营销经典案例
  • windows2008网站西安seo霸屏
  • WordPress图片裁减成都关键词优化报价
  • 人才市场网站建设论文枸橼酸西地那非片的作用及功效
  • 功能性网站开发seo标签优化
  • 什么专业学做网站今天nba新闻最新消息
  • wordpress安装插件无法创建目录360优化大师官方官网
  • 怎么把网站黑了企业seo排名
  • 钦州住房和城乡建设委员会网站seo排名优化首页
  • 网站开发流程属于制作与开发百度seo排名优化费用
  • 网站服务器用什么好处属于seo网站优化
  • 网站 栏目 英语seo辅助工具
  • 网站建设费怎么写会计科目广告公司推广文案
  • 网页版传奇合击版本北京seo工程师
  • 铜陵网站建设搜索引擎优化简称seo
  • 网站管理员怎么做seo网站优化教程
  • 杨浦企业网站建设长沙网络推广外包
  • 如何用国外网站做头条上海网站搜索引擎优化
  • wordpress 以下属于网站seo的内容是
  • 武汉网站制作公司杭州优化seo
  • 网站开发如何模块化统计工具
  • 深圳网站建设简介企业培训课程ppt
  • 邢台网站建设公司软文营销怎么写
  • 网站集约化建设行业规定谈谈对seo的理解
  • 网站设计的资质叫什么域名注册网站哪个好
  • 中卫网站推广优化公司免费b站推广网站
  • 阳江市住房和城乡建设局网站提升seo排名平台
  • 网站模板用什么软件做wordpress官网入口
  • 做装修的网站是不是骗人的域名解析查询