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

淘客网站怎么做百度总部公司地址在哪里

淘客网站怎么做,百度总部公司地址在哪里,海城区建设局网站,华东建设安装有限公司网站257. 二叉树的所有路径 给你一个二叉树的根节点 root ,按 任意顺序 ,返回所有从根节点到叶子节点的路径。 叶子节点 是指没有子节点的节点。 示例 1: 输入:root [1,2,3,null,5] 输出:["1->2->5",&…

257. 二叉树的所有路径

给你一个二叉树的根节点 root ,按 任意顺序 ,返回所有从根节点到叶子节点的路径。

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

示例 1:

输入:root = [1,2,3,null,5]
输出:["1->2->5","1->3"]

示例 2:

输入:root = [1]
输出:["1"]

思路:递归,结束条件是一个结点没有左孩子和右孩子。题目提示中写到至少会有一个根节点,那么不用判断树空的情况。

代码实现:

class Solution {void generate(TreeNode *node, string path, vector<string> &result) {path += to_string(node->val);if(node->left && !node->left->left && !node->left->right) {result.push_back(path);return;}if(node->left) generate(node->left, path + "->", result);if(node->right) generate(node->right, path + "->", result);}    vector<string> binaryTreePaths(TreeNode* root) {string path = "";vector<string> result;//if(!root) return result;generate(root, path, result);return result;}
};

404. 左叶子之和

给定二叉树的根节点 root ,返回所有左叶子之和。

示例 1:

输入: root = [3,9,20,null,null,15,7] 
输出: 24 
解释: 在这个二叉树中,有两个左叶子,分别是 9 和 15,所以返回 24

示例 2:

输入: root = [1]
输出: 0

思路:递归,迭代都可以。迭代的话,前中后续都可行,下面的代码是后序遍历,注意判断左叶子结点即可。递归的判定条件也是相同的。

代码实现1:迭代

class Solution {
public:int sumOfLeftLeaves(TreeNode* root) {stack<TreeNode *> stk;if(!root) return 0;stk.push(root);int ret = 0;TreeNode *node;while(!stk.empty()) {node = stk.top();stk.pop();if(node->left && !node->left->left && !node->left->right) ret += node->left->val;if(node->left) stk.push(node->left);if(node->right) stk.push(node->right);}return ret;}
};

代码实现2:递归

class Solution {
public:int sumOfLeftLeaves(TreeNode* root) {if(!root) return 0;int leftValue = 0;if(root->left && !root->left->left && !root->left->right) {leftValue = root->left->val;}return leftValue + sumOfLeftLeaves(root->left) + sumOfLeftLeaves(root->right);}
};

112. 路径总和

给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。判断该树中是否存在 根节点到叶子节点 的路径,这条路径上所有节点值相加等于目标和 targetSum 。如果存在,返回 true ;否则,返回 false 。

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

示例 1:

输入:root = [5,4,8,11,null,13,4,7,2,null,null,null,1], targetSum = 22
输出:true
解释:等于目标和的根节点到叶节点路径如上图所示。

示例 2:

输入:root = [1,2,3], targetSum = 5
输出:false
解释:树中存在两条根节点到叶子节点的路径:
(1 --> 2): 和为 3
(1 --> 3): 和为 4
不存在 sum = 5 的根节点到叶子节点的路径。

示例 3:

输入:root = [], targetSum = 0
输出:false
解释:由于树是空的,所以不存在根节点到叶子节点的路径。

思路:递归+回溯,当得到的结果不满足时,需要往回退一步,寻找新的可能满足需求的路径。

代码实现:

class Solution {
public:bool calculate(TreeNode *node, int count) {if(!node->left && !node->right && count == 0) return true;if(!node->left && !node->right) return false;if(node->left) {count -= node->left->val;if(calculate(node->left, count)) return true;count += node->left->val;}if(node->right) {count -= node->right->val;if(calculate(node->right, count)) return true;count += node->right->val;}return false;}bool hasPathSum(TreeNode* root, int targetSum) {if(!root) return false;return calculate(root, targetSum - root->val);}
};
http://www.dinnco.com/news/62151.html

相关文章:

  • 找人做网站流程中国新闻网
  • 网站编排成人短期电脑培训班学费
  • 优秀网站推广方案国内seo工具
  • 国外的设计网站app吗淘宝关键词搜索排行榜
  • 上海工作网站广告平台网站有哪些
  • 个人网站栏目设计qq群引流推广平台
  • 那个视频网站最好最全网址俄罗斯搜索引擎
  • 免费一键建站官网大全今天的新闻内容
  • 手机网站微信链接怎么做哪个合肥seo好
  • 世界网站制作百度热度指数排行
  • dw和asp.net动态网站开发足球最新世界排名表
  • 单页面网站制作教程seo优化外包
  • 做企业网站的好处百度旗下所有app列表
  • 信诺盛世网站百度软件下载
  • 建站之星用做什么网站南城网站优化公司
  • 新站点seo联系方式百度下载安装免费
  • 福州建设局网站seo是什么单位
  • 网站被篡改处理企业如何网络推广
  • 网站策划方法百度网盘资源搜索入口
  • 网站五合一建设广州新闻播报
  • 镇江网站制作优化石家庄最新疫情
  • 天津企业网站制作广州网站优化排名系统
  • 做外贸的网站电商网课
  • 可以做烟的网站吗石家庄网络营销网站推广
  • 公司网站系统深圳网站建设
  • 大连开发区做网站的公司营销软文代写
  • 交互式网站鹤壁seo推广
  • 安阳公司做网站营销推广技巧
  • 自助网站制作关键词的作用
  • 郑州建站软件百度网站推广一年多少钱