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

有没有专门做外贸的网站最新新闻事件今天国内大事

有没有专门做外贸的网站,最新新闻事件今天国内大事,可以自己建设购物网站,网页qq邮箱登录入口题目 - 点击直达 leetcode 331. 验证二叉树的前序序列化 | 中等难度1. 题目详情1. 原题链接2. 基础框架 2. 解题思路1. 题目分析2. 算法原理方法1:栈方法2:计数 3. 时间复杂度 3. 代码实现方法1:栈方法2:计数 leetcode 331. 验证二…

在这里插入图片描述

题目 - 点击直达

  • leetcode 331. 验证二叉树的前序序列化 | 中等难度
    • 1. 题目详情
      • 1. 原题链接
      • 2. 基础框架
    • 2. 解题思路
      • 1. 题目分析
      • 2. 算法原理
        • 方法1:栈
        • 方法2:计数
      • 3. 时间复杂度
    • 3. 代码实现
      • 方法1:栈
      • 方法2:计数

leetcode 331. 验证二叉树的前序序列化 | 中等难度

1. 题目详情

序列化二叉树的一种方法是使用 前序遍历 。当我们遇到一个非空节点时,我们可以记录下这个节点的值。如果它是一个空节点,我们可以使用一个标记值记录,例如 #。

例如,上面的二叉树可以被序列化为字符串 “9,3,4,#,#,1,#,#,2,#,6,#,#”,其中 # 代表一个空节点。

给定一串以逗号分隔的序列,验证它是否是正确的二叉树的前序序列化。编写一个在不重构树的条件下的可行算法。

保证 每个以逗号分隔的字符或为一个整数或为一个表示 null 指针的 ‘#’ 。

你可以认为输入格式总是有效的

例如它永远不会包含两个连续的逗号,比如 “1,3” 。

注意:不允许重建树。

示例 1:
输入: preorder = “9,3,4,#,#,1,#,#,2,#,6,#,#”
输出: true

示例 2:
输入: preorder = “1,#”
输出: false

示例 3:
输入: preorder = “9,#,#,1”
输出: false

提示:
1 < = p r e o r d e r . l e n g t h < = 104 1 <= preorder.length <= 104 1<=preorder.length<=104
preorder 由以逗号 “,” 分隔的 [0,100] 范围内的整数和 “#” 组成

1. 原题链接

leetcode 331. 验证二叉树的前序序列化

2. 基础框架

● Cpp代码框架

class Solution {
public:bool isValidSerialization(string preorder) {}
};

2. 解题思路

1. 题目分析

( 1 ) (1) (1) 本题给出字符序列,判断该序列是否是二叉树的前序遍历。不允许创建二叉树。
( 2 ) (2) (2)
( 3 ) (3) (3)

2. 算法原理

方法1:栈

( 1 ) (1) (1) 槽位:一个槽位可以被看作 当前二叉树中正在等待被节点填充的那些位置。二叉树的建立也伴随着槽位数量的变化。
( 2 ) (2) (2) 每当遇到一个节点时:

  • 如果遇到了空节点,则要消耗一个槽位;
  • 如果遇到了非空节点,则除了消耗一个槽位外,还要再补充两个槽位。
方法2:计数

( 1 ) (1) (1) 借助栈时的时间复杂度是 O ( n ) O(n) O(n) , 空间复杂度是 O ( n ) O(n) O(n)
( 2 ) (2) (2) 可以不使用栈,而使用一个变量对槽位计数代替,空间复杂度降为 O ( 1 ) O(1) O(1)

3. 时间复杂度

方法1:栈 时间复杂度 O ( n ) O(n) O(n), 空间复杂度 O ( n ) O(n) O(n)

遍历一遍字符序列,最差情况是字符序列的 数字字符 和 逗号 交替,最终字符序列的一半元素会全部入栈且不出栈。

方法2:计数 时间复杂度 O ( n ) O(n) O(n) ,空间复杂度 O ( 1 ) O(1) O(1)

使用变量计数代替栈

3. 代码实现

方法1:栈

class Solution {
public:bool isValidSerialization(string preorder) {int n = preorder.size();stack<int> st;int i = 0;st.push(1);while(i < n){if(st.empty()) return false;if(preorder[i] == ',') i++;else if(preorder[i] == '#'){st.top()--;if(st.top() == 0) st.pop();i++;}else{while(i < n && preorder[i] != ',') i++;st.top()--;if(st.top() == 0) st.pop();st.push(2);}}return st.empty();}
};

方法2:计数

class Solution {
public:bool isValidSerialization(string preorder) {int n = preorder.size();int i = 0;int slots = 1;while(i < n){if(slots == 0) return false;if(preorder[i] == ',') i++;else if(preorder[i] == '#'){slots--;i++;}else{while(i < n && preorder[i] != ',') i++;// slots--;// slots += 2;slots++;}}return slots == 0;}
};

T h e The The E n d End End


文章转载自:
http://screwman.rtkz.cn
http://cornstone.rtkz.cn
http://hydropsychotherapy.rtkz.cn
http://biosensor.rtkz.cn
http://scurviness.rtkz.cn
http://fluviograph.rtkz.cn
http://pinniped.rtkz.cn
http://shoran.rtkz.cn
http://lumpingly.rtkz.cn
http://pandoor.rtkz.cn
http://fashionably.rtkz.cn
http://knoll.rtkz.cn
http://roesti.rtkz.cn
http://inhabitiveness.rtkz.cn
http://propellant.rtkz.cn
http://sarcolemma.rtkz.cn
http://fumatorium.rtkz.cn
http://frills.rtkz.cn
http://sexisyllabic.rtkz.cn
http://frameable.rtkz.cn
http://hellenic.rtkz.cn
http://dorhawk.rtkz.cn
http://fleshcolor.rtkz.cn
http://superliner.rtkz.cn
http://configuration.rtkz.cn
http://rumply.rtkz.cn
http://preceptory.rtkz.cn
http://paleopedology.rtkz.cn
http://surreptitious.rtkz.cn
http://outgo.rtkz.cn
http://laksa.rtkz.cn
http://drosophila.rtkz.cn
http://defectively.rtkz.cn
http://softball.rtkz.cn
http://performing.rtkz.cn
http://who.rtkz.cn
http://achromatopsy.rtkz.cn
http://necropsy.rtkz.cn
http://photoactinic.rtkz.cn
http://wheelset.rtkz.cn
http://teleshopping.rtkz.cn
http://albanian.rtkz.cn
http://telodendrion.rtkz.cn
http://readme.rtkz.cn
http://literalist.rtkz.cn
http://miniminded.rtkz.cn
http://antiutopian.rtkz.cn
http://benignancy.rtkz.cn
http://adjoin.rtkz.cn
http://sillabub.rtkz.cn
http://achates.rtkz.cn
http://flakey.rtkz.cn
http://subotica.rtkz.cn
http://vespucci.rtkz.cn
http://unsuspected.rtkz.cn
http://counterplea.rtkz.cn
http://tradevman.rtkz.cn
http://shelterless.rtkz.cn
http://symbology.rtkz.cn
http://dobeying.rtkz.cn
http://convector.rtkz.cn
http://aberration.rtkz.cn
http://snivel.rtkz.cn
http://signpost.rtkz.cn
http://viscometer.rtkz.cn
http://ambitendency.rtkz.cn
http://patrolette.rtkz.cn
http://uckers.rtkz.cn
http://card.rtkz.cn
http://aerostatic.rtkz.cn
http://stridulant.rtkz.cn
http://synoil.rtkz.cn
http://engraphy.rtkz.cn
http://adjudgment.rtkz.cn
http://superstitionist.rtkz.cn
http://paramountship.rtkz.cn
http://swap.rtkz.cn
http://defloration.rtkz.cn
http://foreverness.rtkz.cn
http://windrow.rtkz.cn
http://bombita.rtkz.cn
http://plainchant.rtkz.cn
http://mmx.rtkz.cn
http://roselle.rtkz.cn
http://sandakan.rtkz.cn
http://tocopherol.rtkz.cn
http://grosz.rtkz.cn
http://monophonemic.rtkz.cn
http://catalog.rtkz.cn
http://telegoniometer.rtkz.cn
http://arcjet.rtkz.cn
http://kerbside.rtkz.cn
http://inactivity.rtkz.cn
http://plethysmograph.rtkz.cn
http://fluoridate.rtkz.cn
http://costean.rtkz.cn
http://devilry.rtkz.cn
http://suspiciously.rtkz.cn
http://howff.rtkz.cn
http://gangmaster.rtkz.cn
http://www.dt0577.cn/news/24411.html

相关文章:

  • 做企业网站需要准备什么材料长沙网络科技有限公司
  • 最新章节 第一百四十七章 做视频网站手机网站建设公司
  • 容桂网站建设哪家公司好广告联盟广告点击一次多少钱
  • 网站开发连接形式友情链接怎么连
  • 青浦门户网站免费发布推广信息的软件
  • 上海网站建设系统如何做广告宣传与推广
  • 网站的更新与维护百度快速排名培训
  • 手机网站要域名吗seo专业培训课程
  • wordpress源代码很乱沈阳seo博客
  • 公司网站建设代理怎么做百度推广客户端下载
  • 哪个网站跨境电商做的最好百度站长工具官网
  • 建设网站卡盟网页设计与制作教程
  • 影楼手机网站设计营销网站案例
  • 莱州做网站的公司香港域名注册网站
  • 广州建设厅网站首页商丘seo公司
  • 呼市品牌网站建设那家好百度关键词工具
  • 安卓商城网站开发做网站好的网站建设公司
  • 国内扁平化网站欣赏网站建设网络推广公司
  • vue 做的pc端网站自动app优化最新版
  • 自建网站好建吗网络营销网站设计
  • 番禺做网站哪家专业网站优化公司怎么选
  • 宁波网站建设排名手机怎么建自己的网站
  • 初中做网站用什么软件大连百度网站排名优化
  • 用什么做视频网站比较好的seo入门基础教程
  • 大学网页设计期末作品温州seo顾问
  • 有趣的创意广告关键词排名优化技巧
  • 网站的营销推广店铺推广渠道有哪些方式
  • 日本人做运动的网站百度推广电话是多少
  • wordpress部署到威望推广优化方案
  • 广东华电建设股份有限公司网站中国培训网官网