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

网站上的招牌图怎么做小程序源码php

网站上的招牌图怎么做,小程序源码php,在线直播,最新营销模式有哪些阅读目录 1. 题目2. 解题思路3. 代码实现 1. 题目 2. 解题思路 二叉树的问题首先我们要想想是否能用递归来解决#xff0c;本题也不例外#xff0c;而递归的关键是找到子问题。 我们首先来看看一棵最简单的树#xff0c;也就是示例 1。这样的一棵树总共有六条路径#xf… 阅读目录 1. 题目2. 解题思路3. 代码实现 1. 题目 2. 解题思路 二叉树的问题首先我们要想想是否能用递归来解决本题也不例外而递归的关键是找到子问题。 我们首先来看看一棵最简单的树也就是示例 1。这样的一棵树总共有六条路径分别是根节点、左节点-根节点、右节点-根节点、左节点、右节点、左节点-根节点-右节点我们用一个大小为 6 的数组 rootSum 来分别表示这六条路径的路径和那么所求的最大路径和即为 rootSum 的最大值。 需要注意当某一个节点为空的时候比如左节点为空那么左节点-根节点路径和为根节点的值左节点贡献值为 0。而单独左节点的路径不存在路径和应该设置为一个极大的负值。 接下来我们再考虑一个更复杂的树这棵树的根节点有左右两棵子树每一棵子树都是类似上面示例 1 的一棵树。那么我们可以很容易地得到左右子树的路径和数组 leftSum 和 rightSum 接下来我们要做的就是如何根据这两个数组得到整棵树的路径和数组 rootSum rootSum 仍然有 6 条路径其中 只有一个根节点的路径rootSum[0]root-val左节点-根节点的路径这时候由于左节点是一棵子树所以只有包含子树中根节点的路径才能继续和当前的根节点组成新的路径也就是子树的前三条路径然后我们取其中最大的一条即可rootSum[1]root-val max(leftSum[0:3))右节点-根节点的路径这个和上面的类似rootSum[2]root-val max(rightSum[0:3))左节点也即是单独左子树组成的最大路径rootSum[3]max(leftSum[0:6))右节点也即是单独右子树组成的最大路径rootSum[4]max(rightSum[0:6))左节点-根节点-右节点也就是左子树的路径包含左子树的根节点右子树的路径包含右子树的根节点rootSum[5]max(leftSum[0:3)) root-val max(rightSum[0:3)) 时间复杂度为 O ( n ) O(n) O(n) n n n 代表节点总数每个节点都需要进行遍历一次空间复杂度为 O ( n ) O(n) O(n)每个节点都需要存储 6 个状态值。 3. 代码实现 /*** 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:vectorint getNodePathSum(TreeNode* root) {int leftRootSum 0, leftMaxSum -10000;if (root-left ! nullptr) {vectorint leftSum getNodePathSum(root-left);leftRootSum *std::max_element(leftSum.begin(), leftSum.begin() 3);leftMaxSum *std::max_element(leftSum.begin(), leftSum.end());}int rightRootSum 0, rightMaxSum -10000;if (root-right ! nullptr) {vectorint rightSum getNodePathSum(root-right);rightRootSum *std::max_element(rightSum.begin(), rightSum.begin() 3);rightMaxSum *std::max_element(rightSum.begin(), rightSum.end());}vectorint rootSum(6, 0);rootSum[0] root-val;rootSum[1] leftRootSum root-val;rootSum[2] rightRootSum root-val;rootSum[3] leftMaxSum;rootSum[4] rightMaxSum;rootSum[5] leftRootSum root-val rightRootSum;return rootSum;}int maxPathSum(TreeNode* root) {vectorint sum getNodePathSum(root);return *std::max_element(sum.begin(), sum.end());} };
http://www.hkea.cn/news/14305659/

相关文章:

  • 做网站违反广告法手机代理ip免费网址
  • 松江品划网站建设推广优化品牌seo关键词
  • 哈尔滨网站建设公司简单的wordpress模板下载
  • 项目定制开发网站网站开发职业环境分析
  • 看守所加强自身网站建设工作总结莘县做网站
  • 做网站还要买服务器吗旅游网站开发的背景及意义
  • 门户网站安全建设wordpress调取多个分类文章
  • 重庆建设医院官方网站视频直播软件有哪些
  • 做陶瓷公司网站vue做门户网站
  • 在哪人网站要以接it项目做2021深圳装修公司排名前十强
  • 个人做电影网站服务器放国外安全吗怎么才能创个网站
  • 简述网站建设和推广评价指标怎么提交网站
  • 石家庄网站建设团队西安专业网络推广平台
  • 在服务器网站上做跳转页面跳转页面免费软件的定义
  • 民营医院建设网站搭建网页游戏多少钱
  • 网站建设价格标准杭州全案推广
  • 不同用户入口的网站样板iis 无法访问此网站
  • 适用于建设微型网站个人可以备案什么网站
  • 企业网站营销推广方案如何外贸营销推广
  • 网站推广的软件大学生网页设计期末作业
  • 才艺多网站建设平台手机版网站怎样做推广
  • wordpress教程 微信为网站做seo需要什么软件
  • 网站后台如何上传文件构建一个商务网站的步骤有哪些
  • 建设个人技术网站济南网站定制
  • 销售网站模板韩国电视剧
  • 黄山搜索引擎优化seo优化推广多少钱
  • 三合一网站建设用途下载什么网站做吃的
  • 六安网站制作哪里有做网站需要考虑哪些问题
  • 花里胡哨的网站网站优化能发外链的gvm网站大全
  • 网站建设地图怎么设置区块链软件开发