简单树结构的实现

PHP树结构实现
<?php
//节点类
class TreeNode
{
    //节点数据
    public $data = null;
    //子节点对象
    public $children = [];
    //构造方法传入data
    public function __construct(string $data = null)
    {
        $this->data = $data;
    }
    //添加子节点
    public function addChildren(TreeNode $treeNode)
    {
        $this->children[] = $treeNode;
    }
}

//树结构类
class Tree
{
    //根节点
    public $root = null;
    //传入根节点
    public function __construct(TreeNode $treeNode)
    {
        $this->root = $treeNode;
    }
    //遍历树
    public function traverse(TreeNode $treeNode, int $level = 0)
    {
        //传入节点,默认深度0
        if ($treeNode) {
            //输出深度和数据
            echo str_repeat('-', $level) . $treeNode->data . '<br>';
            //递归遍历该节点子节点、深度+1
            foreach ($treeNode->children as $child) {
                $this->traverse($child, $level + 1);
            }
        }
    }
}

$ceo = new TreeNode('ceo');

$tree = new Tree($ceo);

$cfo = new TreeNode('cfo');
$cto = new TreeNode('cto');
$cmo = new TreeNode('cmo');
$coo = new TreeNode('coo');

$ceo->addChildren($cfo);
$ceo->addChildren($cto);
$ceo->addChildren($cmo);
$ceo->addChildren($coo);

$seniorArchitect = new TreeNode("Senior Architect");
$softwareEngineer = new TreeNode("SoftwareEngineer");

$userInterfaceDesigner = new TreeNode("userInterface Designer");
$qualityAssuranceEngineer = new TreeNode("qualityAssurance Engineer");


$cto->addChildren($seniorArchitect);
$seniorArchitect->addChildren($softwareEngineer);

$cto->addChildren($userInterfaceDesigner);
$cto->addChildren($qualityAssuranceEngineer);

$tree->traverse($tree->root);

 

转载于:https://www.cnblogs.com/wwjchina/p/9626352.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值