这篇文章主要介绍了php实现判断二叉树是否对称的方法,涉及php递归二叉树判断节点的相关操作技巧,对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);
}
以上就是本篇文章的所有内容。希望对大家的学习有所帮助!!
相关推荐:
实例比较php方法重载的两种方式
php方法调用模式与函数调用模式简例
php方法追踪
以上就是php实现判断二叉树是否对称的方法的详细内容。