二叉树遍历算法
<p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 二叉树遍历,是值从根节点出发,按照某种次序依次访问二叉树中的所有节点,使得每个节点被访问一次且仅被访问依次。 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;text-align:center;"> <img src="/static/imghw/default1.png" data-src="http://lanecn-upload.stor.sinaapp.com/image/20140709_1404896527_874807.gif" class="lazy" title="20140709_1404896527_874807.gif" alt="tupan062.gif" style="max-width:90%"> </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;text-align:center;"> 图是百度搜的。。。谢谢提供图的英雄。。 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 前序遍历二叉树:如果二叉树为空则返回,若二叉树非空,则先遍历左树,再遍历右树,遍历顺序为ABCDEGF。 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 中序遍历二叉树:如果二叉树为空则返回,若二叉树非空,则从根节点开始,中序遍历根节点的左子树,然后是访问根节点,最后中序遍历右子树,遍历顺序为CBEGDFA。 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 后序遍历二叉树:如果二叉树为空则返回,若二叉树非空,则从左到右先叶子后节点的访问遍历访问左右子树,最后是访问根节点。访问顺序为CGEFDBA。 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 层序遍历二叉树:如果二叉树为空则返回,若二叉树非空,则从树的第一层,也就是根节点开始访问,从上而下逐层遍历,在同一层中,按照从左到右的顺序对节点逐个访问。访问顺序为ABCDEFG。 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> <br> </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 现在,我们用PHP代码,来遍历二叉树结构。二叉树是放一个大数组,每一个节点都有三个字段,data表示这个节点的值,lChild表示这个节点的左边子节点,rChild表示这个节点的右边子节点。二叉树的结构我们用上面那张图。 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> <br> </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 二叉树结构代码如下: </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> <br> </p> <pre class='brush:php;toolbar:false;'> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> <br /> </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> <?php </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> //二叉树 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> $arr = array( </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'data' => 'A', </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'lChild' => array( </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'data' => 'B', </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'lChild' => array( </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'data' => 'C', </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'lChild' => array(), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'rChild' => array(), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> ), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'rChild' => array( </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'data' => 'D', </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'lChild' => array( </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'data' => 'E', </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'lChild' => array(), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'rChild' => array( </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'data' => 'G', </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'lChild' => array(), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'rChild' => array(), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> ), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> ), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'rChild' => array( </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'data' => 'F', </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'lChild' => array(), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'rChild' => array(), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> ), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> ), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> ), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> 'rChild' => array(), </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> ); </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> <br /> </p>
遍历算法一:前序遍历二叉树
<p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> <br /> </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> <?php </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> //前序遍历二叉树算法 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> echo '前序遍历二叉树算法:'; </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> PreOrderTraverse($arr); </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> echo '<Br>'; </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> function PreOrderTraverse($node){ </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> if(empty($node)){ </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> return; </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> } </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> //输出值 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> print_r($node['data']); </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> //左节点 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> PreOrderTraverse($node['lChild']); </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> //右节点 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> PreOrderTraverse($node['rChild']); </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> } </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> <br /> </p>
遍历算法二:中序遍历二叉树
<p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> <br /> </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> <?php </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> //中序遍历二叉树算法 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> echo '中序遍历二叉树算法:'; </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> inOrderTraverse($arr); </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> echo '<Br>'; </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> function inOrderTraverse($node){ </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> if(empty($node)){ </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> return; </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> } </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> //左节点 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> inOrderTraverse($node['lChild']); </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> //输出值 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> print_r($node['data']); </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> //右节点 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> inOrderTraverse($node['rChild']); </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> } </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> <br /> </p>
遍历算法三:后序遍历二叉树
<p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> <br /> </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;white-space:normal;"> <?php </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> //后序遍历二叉树算法 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> echo '后序遍历二叉树算法:'; </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> postOrderTraverse($arr); </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> echo '<Br>'; </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> function postOrderTraverse($node){ </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> if(empty($node)){ </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> return; </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> } </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> //左节点 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> postOrderTraverse($node['lChild']); </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> //右节点 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> postOrderTraverse($node['rChild']); </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> //输出值 </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> print_r($node['data']); </p> <p style="box-sizing:border-box;margin-top:0px;margin-bottom:10px;"> } </p>

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Laravel使用其直观的闪存方法简化了处理临时会话数据。这非常适合在您的应用程序中显示简短的消息,警报或通知。 默认情况下,数据仅针对后续请求: $请求 -

PHP客户端URL(curl)扩展是开发人员的强大工具,可以与远程服务器和REST API无缝交互。通过利用Libcurl(备受尊敬的多协议文件传输库),PHP curl促进了有效的执行

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显着减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

您是否想为客户最紧迫的问题提供实时的即时解决方案? 实时聊天使您可以与客户进行实时对话,并立即解决他们的问题。它允许您为您的自定义提供更快的服务

Laravel框架的Storage::download方法提供了一个简洁的API,用于安全地处理文件下载,同时管理文件存储的抽象。 以下是一个在示例控制器中使用Storage::download()的例子:

文章讨论了PHP 5.3中引入的PHP中的晚期静态结合(LSB),从而允许静态方法的运行时分辨率调用以获得更灵活的继承。 LSB的实用应用和潜在的触摸

PHP日志记录对于监视和调试Web应用程序以及捕获关键事件,错误和运行时行为至关重要。它为系统性能提供了宝贵的见解,有助于识别问题并支持更快的故障排除

Laravel的服务容器和服务提供商是其架构的基础。 本文探讨了服务容器,详细信息服务提供商创建,注册,并通过示例演示了实际用法。 我们将从OVE开始
