设为首页 | 加入收藏
首页 WEB开发
PHPJSPASP.NETJavascriptAJAXjQueryNode.js
编程语言
JavaGolangPythonC++C语言VC++C#
数据库
MySQLMSSQLSQLiteMongoDBRedisAccess存储技术
前端开发
HTML+DIV+CSSFlash网页制作技巧
站长之家
建站技巧网络赚钱网站安全
免费资源
开发总结视频教程IDE开发手册面试题
在线工具
Unicode编码 UTF-8编码 URL编码/解码 Unix时间戳 大小写转换 JS代码混淆 JS解密
WEB开发 > PHP >

PHP实现从上往下打印二叉树的方法

发布时间:2018-11-27 | 阅读次数:1482

本文实例讲述了PHP实现从上往下打印二叉树的方法。分享给大家供大家参考,具体如下:

问题

从上往下打印出二叉树的每个节点,同层节点从左至右打印。

解决思路

每层树从左到右打印,所以需要将节点的左右子树存起来,因为先进先出,所以用队列。

实现代码

/*class TreeNode{
  var $val;
  var $left = NULL;
  var $right = NULL;
  function __construct($val){
    $this->val = $val;
  }
}*/
function PrintFromTopToBottom($root)
{
  $queueVal = array();
  $queueNode = array();
  if($root == NULL)
    return $queueVal;
  array_push($queueNode, $root);
  while(!empty($queueNode)){
    $node = array_shift($queueNode);
    if($node->left != NULL)
      array_push($queueNode,$node->left);
    if($node->right != NULL)
      array_push($queueNode,$node->right);
    array_push($queueVal,$node->val);
  }
  return $queueVal;
}

上一篇:PHP获取链表中倒数第K个节点的方法
下一篇:php通过header发送自定义数据方法