php教程

超轻量级php框架startmvc

PHP获取二叉树镜像的方法

更新时间:2020-03-26 04:57:28 作者:startmvc
本文实例讲述了PHP获取二叉树镜像的方法。分享给大家供大家参考,具体如下:问题操作给

本文实例讲述了PHP获取二叉树镜像的方法。分享给大家供大家参考,具体如下:

问题

操作给定的二叉树,将其变换为源二叉树的镜像。

解决思路

翻转二叉树,有递归和非递归两种方式,非递归就是使用队列。

实现代码


<?php
/*class TreeNode{
 var $val;
 var $left = NULL;
 var $right = NULL;
 function __construct($val){
 $this->val = $val;
 }
}*/
function Mirror(&$root)
{
 if($root == NULL)
 return 0;
 $queue = array();
 array_push($queue, $root);
 while(!empty($queue)){
 $node = array_shift($queue);
 $tmp = $node->left;
 $node->left = $node->right;
 $node->right = $tmp;
 if($node->left != NULL)
 array_push($queue, $node->left);
 if($node->right != NULL)
 array_push($queue, $node->right);
 }
}

PHP 二叉树 镜像