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

广州网站建设信科网络/网站流量统计查询

广州网站建设信科网络,网站流量统计查询,流媒体视频网站开发,wordpress导航栏编辑leetcode-654. 最大二叉树 给定一个不重复的整数数组 nums 。 最大二叉树 可以用下面的算法从 nums 递归地构建: 创建一个根节点,其值为 nums 中的最大值。 递归地在最大值 左边 的 子数组前缀上 构建左子树。 递归地在最大值 右边 的 子数组后缀上 构建右子树。 …

leetcode-654. 最大二叉树
给定一个不重复的整数数组 nums 。

最大二叉树 可以用下面的算法从 nums 递归地构建:
创建一个根节点,其值为 nums 中的最大值。
递归地在最大值 左边 的 子数组前缀上 构建左子树。
递归地在最大值 右边 的 子数组后缀上 构建右子树。

class Solution {
public:TreeNode* constructMaximumBinaryTreeHelper(vector<int>& nums, int start, int end) {if (start > end)return NULL;// 找到 start~end的最大值int max_value = nums[start];int max_index = start;for(int i = start + 1; i <= end; i++) {if (max_value < nums[i]) {max_value = nums[i];max_index = i;}}TreeNode* root = new TreeNode(max_value);root->left = constructMaximumBinaryTreeHelper(nums, start, max_index - 1);root->right = constructMaximumBinaryTreeHelper(nums, max_index + 1, end);return root;}TreeNode* constructMaximumBinaryTree(vector<int>& nums) {return constructMaximumBinaryTreeHelper(nums, 0, nums.size()-1);}
};

时间复杂度:O(n^2)。constructMaximumBinaryTree 一共被调用 n 次。
每次递归寻找根节点时,需要遍历当前索引范围内所有元素找出最大值。
一般情况下,每次遍历的复杂度为 O(logn),总复杂度为 O(nlogn)。
最坏的情况下,数组 nums 有序,总的复杂度为 O(n^2)

空间复杂度:O(n)。递归调用深度为 n。
平均情况下,长度为 n 的数组递归调用深度为 O(logn)

单调栈做法

class Solution {
public:TreeNode* constructMaximumBinaryTree(vector<int>& nums) {stack<TreeNode*> s;int len = nums.size();TreeNode *curNode;for(int i = 0; i < len; i++) {curNode = new TreeNode(nums[i]);while (!s.empty() && (s.top())->val <= curNode->val) {TreeNode *tmp = s.top();s.pop();// 挂载问题,将弹出的栈顶元素挂在新的栈顶的右侧呢还是curNode的左侧呢if(!s.empty() && (s.top())->val <= curNode->val)(s.top())->right = tmp;elsecurNode->left = tmp;}s.push(curNode);}// 降序的处理// 比如栈中从底到顶部是 6 5 4 3 2 1// 则不断弹出一个,并让新的栈顶元素的right指向当前元素curNode = s.top();s.pop();while(!s.empty()) {(s.top())->right = curNode;curNode = s.top();s.pop();}return curNode;}
};

nums就是一个二叉树的中序序列
左-根-右

http://www.jmfq.cn/news/5257549.html

相关文章:

  • 国内使用wordpress/百度seo推广
  • 百度站点管理/今日新闻最新头条10条
  • jsp做网站实例教程/福州seo
  • 机票酒店 网站建设/打开百度一下网页版
  • 浅析淘宝网站的建设与运营论文/快手seo软件下载
  • 金融直播室网站建设/小程序商城
  • 上海企业网站备案/婚恋网站排名前10
  • 提升网站建设/竞价托管就选微竞价
  • 旅游网站开发需求/网络营销的目标
  • 网站备案主体授权书/竞价托管多少钱一个月
  • 免费虚拟机安卓版/seo关键词排名技术
  • 东莞家具网站建设/小吃培训2000元学6项
  • 520高清网站三级黄色软件男女做/安卓优化大师官网下载
  • 南京网站推广¥做下拉去118cr/nba排名2021最新排名
  • 做3d图的网站/设计网站模板
  • 网站群建设管理办法/网站优化排名方法有哪些
  • 做电商网站电商公司/武汉seo招聘
  • 企业建站公司报价/拉新推广一手接单平台
  • 曲阜网站建设哪家便宜/百度网页入口
  • 用dw做网站怎么单独修改字体/网络推广运营
  • css不规则网站导航怎么做/建站网站
  • 代做毕业设计网站多少钱/做直销去哪里找客户
  • 浦东网站建设公司/谷歌推广外包
  • 佛山网站建设外包/电脑课程培训零基础
  • 南京汽车企业网站建设/1688黄页大全进口
  • 丽水网站建设专业的公司/seo学校培训班
  • wordpress sns/知乎seo排名帝搜软件
  • WordPress多站点绑定域名/快点tv下载安装
  • 横沥做网站的电话/奶茶推广软文200字
  • php内容管理系统cms/怎样优化网站关键词排名靠前