PHP根据树的前序遍历和中序遍历构造树并输出后
网络编程 2021-07-05 08:24www.168986.cn编程入门
这篇文章主要介绍了PHP根据树的前序遍历和中序遍历构造树并输出后序遍历的方法,涉及php数据结构与算法中关于数的遍历相关操作技巧,需要的朋友可以参考下
本文实例讲述了PHP根据树的前序遍历和中序遍历构造树并输出后序遍历的方法。分享给大家供大家参考,具体如下:
先来看看前序遍历、中序遍历与后序遍历原理图:
根据树的前序遍历和中序遍历构造树并输出后序遍历代码如下:
<?php class BinaryTreeNode{ public $m_value; public $m_left; public $m_right; } function ConstructCore($preorder,$inorder){ if(count($preorder)!=count($inorder) || count($preorder)==0 || count($inorder)==0) return null; $headNode=new BinaryTreeNode; $headNode->m_value=$preorder[0]; if(count($preorder)==1){ $headNode->m_left=null; $headNode->m_right=null; return $headNode; } array_shift($preorder); $pos=array_search($headNode->m_value,$inorder); $leftin=array_slice($inorder,0,$pos); $rightin=array_slice($inorder,$pos+1); $leftpre=array_slice($preorder,0,$pos); $rightpre=array_slice($preorder,$pos); $headNode->m_left=ConstructCore($leftpre,$leftin); $headNode->m_right=ConstructCore($rightpre,$rightin); return $headNode; } $pre=array(1,2,4,7,3,5,6,8); $in=array(4,7,2,1,5,3,8,6); $tree=ConstructCore($pre,$in); function tail($tree){ if($tree->m_right!=null) echo tail($tree->m_right); if($tree->m_left!=null) echo tail($tree->m_left); echo $tree->m_value; } tail($tree); ?>
运行结果:
86537421
更多关于PHP相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》及《》
希望本文所述对大家PHP程序设计有所帮助。
编程语言
- 机械手焊接机器人编程 机械手焊接设备编程
- vb数据库编程实例,vb做数据库
- tiobe世界编程语言排行榜,全球编程语言排行
- 成都java编程培训 成都it编程培训中心
- 编程基础培训,编程基础知识培训
- flash游戏编程基础教程,flash游戏开发教程
- 不会英语能学编程吗 不会英语可以学程序员吗
- 爱心代码编程C语言 爱心代码编程c语言公式
- c语言编程学习入门 c语言编程快速入门
- 西门子plc编程培训 西门子plc编程培训班
- 哪里可以学编程 台州哪里可以学编程
- 少儿编程哪个好 少儿编程哪个品牌好
- 编程是什么意思,图形编程是什么意思
- c语言编程软件下载,c语言编程软件在哪下载
- java编程软件下载,java编程下载手机版
- ug编程培训学校,ug编程培训教程