PHP如何实现判断二叉树是否对称
作者: default|标签:PHP 对称 是否|2018-1-13 11:25
本文主要介绍了PHP实现判断二叉树是否对称的方法,涉及php递归二叉树判断节点的相关操作技巧,需要的朋友可以参考下,希望能帮助到大家。

问题

请实现一个函数,用来判断一颗二叉树是不是对称的。注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的。

题解

递归判断二叉树两侧。

实现代码:


<?php
/*class TreeNode{
 var $val;
 var $left = NULL;
 var $right = NULL;
 function __construct($val){
  $this->val = $val;
 }
}*/
function isSymmetrical($pRoot)
{
 if($pRoot==null) return true;
 return compare($pRoot->left,$pRoot->right);
}
function compare($root1,$root2){
 if($root1==null&&$root2==null) return true;
 if($root1==null||$root2==null) return false;
 if($root1->val!=$root2->val) return false;
 return compare($root1->left,$root2->right)&&compare($root1->right,$root2->left);
}

相关推荐:

JavaScript实现二叉树的先序、中序及后序遍历方法

php中关于完全二叉树的定义方法详解

js实现数据结构: 树和二叉树,二叉树的遍历和基本操作方法

以上就是PHP如何实现判断二叉树是否对称的详细内容,更多请关注php中文网其它相关文章!

617
点赞
收藏
分享:
0/300