LeetCode 1008. 先序遍历构造二叉树(已知先序,求二叉搜索树)

文章目录

    • 1. 题目
    • 2. 解题

1. 题目

返回与给定先序遍历 preorder 相匹配的二叉搜索树(binary search tree)的根结点。

示例:输入:[8,5,1,7,10,12],已知二叉搜索树的先序(根左右)
输出:[8,5,10,1,7,null,12],建立二叉搜索树,返回其root

2. 解题

  • 办法1:排序后就是搜索树的中序,那已知先序和中序,可唯一确定树

  • 办法2:利用二叉搜索树的性质,左子树所有的值都小于root,右子树都大于root
  • 在先序里第一个是根节点的值,然后后面跟着的比它小的是左子树,有大的出现了,就是右子树部分的
  • 递归进行上面步骤
    在这里插入图片描述
class Solution {
public:TreeNode* bstFromPreorder(vector<int>& preorder) {return form(preorder,0,preorder.size()-1);}TreeNode* form(vector<int>& preorder, int start, int end){if(start > end)return NULL;TreeNode* newroot = new TreeNode(preorder[start]);int i;for(i = start+1; i <= end; ++i){if(preorder[i] > preorder[start])break;//右子树的开始 i }newroot->left = form(preorder,start+1,i-1);newroot->right = form(preorder,i,end);return newroot;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/479519.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

美团开源 Logan Web:前端日志在 Web 端的实现

1.前言 Logan 是美团点评推出的大前端日志系统&#xff0c;支持多端环境运行&#xff0c;可为客户端、Web、小程序等用户端环境提供前端日志的存储、收集、上报及分析能力&#xff0c;能够帮助开发人员快速定位并解决端上问题&#xff0c;便于及时响应用户反馈与排除异常。 201…

推荐一个快速定位深度学习代码bug的炼丹神器!

文 | McGL源 | 知乎写深度学习网络代码&#xff0c;最大的挑战之一&#xff0c;尤其对新手来说&#xff0c;就是把所有的张量维度正确对齐。如果以前就有TensorSensor这个工具&#xff0c;相信我的头发一定比现在更浓密茂盛&#xff01;TensorSensor&#xff0c;码痴教授 Teren…

JAVA AIO

JAVA AIO深入剖析AIO编程AIO编程 Java AIO(NIO.2) &#xff1a; 异步非阻塞&#xff0c;服务器实现模式为一个有效请求一个线程&#xff0c;客户端的I/O请求都是由OS先完成了再通知服务器应用去启动线程进行处理。AIO:异步非阻塞&#xff0c;基于NIO的&#xff0c;可以称之为N…

研讨会 | 知识图谱引领认知智能+

本文转载自公众号&#xff1a;中国计算机学会。本论坛将于 CNCC2019 中国计算机大会第一天&#xff08;10月17日&#xff09;在苏州金鸡湖国际会议中心 A102 会议室举行&#xff0c;共邀微软、阿里巴巴、华为、小米、浙江大学、苏州大学等机构的专家与你探讨。知识图谱是一种用…

从源码说说dispatchTouchEvent与onTouchEvent的关系以及OnTouchListener的用法

为什么要说这个问题呢&#xff0c;这段时间还是在SeekBar上遇到一些问题&#xff0c;好像ADT并没有给seekBar在xml中提供enabled属性&#xff0c;虽然我们可以在代码中设置&#xff0c;但是它并不能实现下面这个需求&#xff0c;所以我们需要找到别的方式去实现它&#xff0c;也…

LeetCode 617. 合并二叉树

文章目录1. 题目2. 递归解题1. 题目 给定两个二叉树&#xff0c;想象当你将它们中的一个覆盖到另一个上时&#xff0c;两个二叉树的一些节点便会重叠。 你需要将他们合并为一个新的二叉树。合并的规则是如果两个节点重叠&#xff0c;那么将他们的值相加作为节点合并后的新值&…

哪些 Python 库让你相见恨晚?

原文链接&#xff1a;https://www.zhihu.com/question/24590883/answer/92420471?utm_sourcewechat_session&utm_mediumsocial&utm_oi57646627422208&utm_contentgroup1_Answer&utm_campaignshareopn Awesome Python 中文版网站​jobbole.github.ioAwesome Py…

BIO,NIO,AIO

BIO,NIO,AIO 介绍一、背景1.1 说明1.2 通信技术整体解决的问题二、Java的I/O演进之路2.1 I/O 模型基本说明2.2 I/O模型Java BIOJava NIOJava AIO2.3 BIO、NIO、AIO 适用场景分析三、BIO,NIO,AIO总结一、背景 1.1 说明 ​ 在Java的软件设计开发中&#xff0c;通信架构是不可避…

学PyTorch还是TensorFlow?

在机器学习领域&#xff0c;面对各类复杂多变的业务问题&#xff0c;构建灵活易调整的模型是高阶机器学习工程师必备的工作能力。然而&#xff0c;许多工程师还是有一个想法上的误区&#xff0c;以为只要掌握了一种深度学习的框架就能走遍天下了。事实上&#xff0c;在机器学习…

Bifrost微前端框架及其在美团闪购中的实践

Bifrost&#xff08;英 [‘bi:frɔst]&#xff09;原意彩虹桥&#xff0c;北欧神话中是连通天地的一条通道。而在漫威电影《雷神》中&#xff0c;Bifrost是神域——阿斯加德&#xff08;Asgard&#xff09;的出入口&#xff0c;神域的人通过它自由穿梭于“九界”&#xff08;指…

设计模式之观察者模式在Listview中的应用

有时候我们会有这么一个需求&#xff0c;在Listview的某个Item上有个按钮&#xff0c;点击这个按钮之后呢&#xff0c;需要对其它的item做一些操作&#xff0c;就像下面这个&#xff1a; 采纳按钮点击之前&#xff1a;采纳按钮点击之后&#xff1a; 简单介绍一下这两张图的意…

新书速递 | 《知识图谱:方法、实践与应用》

本文转载自公众号&#xff1a;博文视点Broadview 。互联网促成了大数据的集聚&#xff0c;大数据进而促进了人工智能算法的进步。近年来知识图谱作为AI领域底层技术被越来越多的人谈起。知识图谱的升温得益于新数据和新算法为规模化知识图谱构建提供了新的技术基础和发展条件&a…

Github Star过万的阿里学长独家干货分享

浅梦是我认识的一位浙大计算机系的学长&#xff0c;目前在阿里从事算法相关的工作。无论在学校还是工作中&#xff0c;他都保持着对新知识的学习和分享。他的github star 1w&#xff0c;世界排名700&#xff0c;参与开发的项目下载量接近30w次。主要涉及「推荐系统」&#xff0…

pytorch 和 tensorflow2.0 方法替换

Embedding初始化 pytorch: Embedding() tf2.0: random.normal() # 验证均值和方差 def confirm(weight):mean np.sum(weight) / dimprint("均值: {}".format(mean))square_sum np.sum((mean - weight) ** 2)print("方差: {}".format(square_sum / dim)…

React Native在美团外卖客户端的实践

MRN简介 MRN&#xff08;Meituan React Native&#xff09; 是基于开源的React Native框架改造并完善而成的一套动态化方案&#xff0c;在开发体验上基本能与原生RN保持一致&#xff0c;同时从业务需求的角度满足从开发、构建、测试、部署、运维的工程化需要。解决了一系列痛点…

论文浅尝 | 使用预训练深度模型和迁移学习方法的端到端模糊实体匹配

论文笔记整理&#xff1a;高凤宁&#xff0c;南京大学硕士&#xff0c;研究方向为知识图谱、实体消解。链接&#xff1a;https://doi.org/10.1145/3308558.3313578动机目前实体匹配过程中实体之间的差异比较微妙&#xff0c;不同的情况下可能会有不同的决策结果&#xff0c;导致…

推荐几个Android开发非常有用的工具(for android studio)

原文地址: http://stormzhang.com/android/2015/05/26/android-tools/ 一晃好久没更新博客了&#xff0c;最近一个月真的很忙&#xff0c;因为公司在准备C轮融资&#xff0c;公司的发展到了一个关键的阶段&#xff0c;自己全部精力投入在公司产品上&#xff0c;这个状态可能还会…

分布式机器学习(下)-联邦学习

原文链接&#xff1a;https://zhuanlan.zhihu.com/p/114028503 本视频来源于Shusen Wang讲解的《分布式机器学习》&#xff0c;总共有三讲&#xff0c;内容和连接如下&#xff1a;并行计算与机器学习&#xff08;上&#xff09;并行计算与机器学习&#xff08;下&#xff09;联…

LeetCode 8. 字符串转换整数 (atoi)

文章目录1. 题目2. 解题1. 题目 示例 1: 输入: "42" 输出: 42示例 2: 输入: " -42" 输出: -42 解释: 第一个非空白字符为 -, 它是一个负号。我们尽可能将负号与后面所有连续出现的数字组合起来&#xff0c;最后得到 -42 。示例 3: 输入: "4193 w…

怎样将Embedding融入传统机器学习框架?

文 | 石塔西源 | 知乎LR本身是一个经典的CTR模型&#xff0c;广泛应用于推荐/广告系统。输入的特征大多数是离散型/组合型。那么对于Embedding技术&#xff0c;如何在不使用深度学习模型的情况下&#xff08;假设就是不能用DNN&#xff09;&#xff0c;融入到LR框架中呢&#x…