2 0 1 9 -5 -7 星 期二 开 始 吧
上 一 题 链 接 Leetcode基础刷题之 PHP 解析(98. Validate Binary Search Tree)
题 目 描 述
给定一个升序的数组,转换为高度平衡的二叉查找树。
题 目 分 析
因为二叉查找树的中序遍历就是一个升序的数组,所以对于升序数组来说,我们只要找到它的中间点,就是二叉查找树的根,那么它的左右子树必然也是这个道理。
/** * Definition for a binary tree node. * class TreeNode { * public $val = null; * public $left = null; * public $right = null; * function __construct($value) { $this->val = $value; } * } */ class Solution { /** * @param Integer[] $nums * @return TreeNode */ function sortedArrayToBST($nums) { return $this->buildTree($nums,0,count($nums)-1); } function buildTree($nums,$l,$r){ if($l>$r){ return ; } $middle=floor(($l+$r)/2); $node=new TreeNode($nums[$middle]); $node->left=$this->buildTree($nums,$l,$middle-1); $node->right=$this->buildTree($nums,$middle+1,$r); return $node; } }
给定一个二叉树,找出树最后一层最左边的结点值。
题 目 分 析
使用层进行遍历,每个层从右往左遍历,这样就能保证我们最后输出的一定是 最后一层的最左结点。
/** * Definition for a binary tree node. * class TreeNode { * public $val = null; * public $left = null; * public $right = null; * function __construct($value) { $this->val = $value; } * } */ class Solution { /** * @param TreeNode $root * @return Integer */ function findBottomLeftValue($root) { $data=[]; array_unshift($data,$root); while(!empty($data)){ $node=array_shift($data); if($node->right !=null) array_push($data,$node->right); if($node->left !=null) array_push($data,$node->left); } return $node->val; } }
树的题目到这里告一段落了
Github整理地址:https://github.com/wuqinqiang/leetcode-php
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Apache Flink 零基础入门(一):基础概念解析
- Apache Flink 零基础入门(一):基础概念解析
- JStorm 源码解析:基础线程模型
- React Hooks 解析(上):基础
- TypeScript基础入门之模块解析(一)
- TypeScript基础入门之模块解析(二)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
一只小鸟告诉我的事
[美]比兹·斯通 / 顾雨佳 / 中信出版社 / 2014-11 / 59.00元
比兹•斯通,无疑是自乔布斯后的又一个硅谷奇迹! 70后的他,出身贫苦,一无所有,却又特立独行,充满智慧。从他这本自传中,我们知道他和乔布斯一样,大学都没读完就辍学做了一名图书封面设计师,然后创建了赞架(Xanga)网站,又进了谷歌。在经济上打了翻身仗后,他毅然放弃了安逸的生活,从零开始,和朋友创建了世界最知名的社交平台推特(Twitter)。当推特奇迹般地改变着世界时,他又悄然离去,创建了自......一起来看看 《一只小鸟告诉我的事》 这本书的介绍吧!