我有一个层次结构中的一组对象。有一个顶部的“根”节点,它有子节点,而子节点又有子节点等等。我试图使用嵌套集模型将这个结构保存到一个数据库中,其中每个节点的每个“边”都被编号以定义层次结构,如Managing Hierarchical Data in MySQL
php - PHP RecursiveIteratorIterator和嵌套集-LMLPHP
(来源:mysql.com
我的问题是计算左值和右值。我通常使用递归迭代器在层次结构上进行迭代,但如果不使用递归函数(该函数通过引用解析索引变量),我就无法计算出数字。
有什么想法吗?
这可能没用,但这是我目前拥有的(不正确的)代码:

$iterator = new RecursiveIteratorIterator(
    new Node_List(array($root)),
    RecursiveIteratorIterator::SELF_FIRST);

$i = 0;
foreach ($iterator as $node) {
    $node->left = ++$i;
    $node->right = ++$i;
}

如您所见,这会产生如下结果:
Node
    Node
    Node

左右值:
Node (1, 2)
    Node (3, 4)
    Node (5, 6)

当他们应该:
Node (1, 6)
    Node (2, 3)
    Node (4, 5)

最佳答案

我想出来了,这是解决办法(简单化):

$iterator = new RecursiveIteratorIterator(
    new Site_Node_List(array($root)),
    RecursiveIteratorIterator::SELF_FIRST);

$sides = array();
$s = 0;
$i = 0;
$parents = array();
foreach ($iterator as $item) {
    $js = array_splice($parents, $depth, count($parents), array($i));
    foreach (array_reverse($js) as $j) {
        $sides[$j]['right'] = ++$s;
    }
    $sides[$i]['left'] = ++$s;
    $i++;
}
foreach (array_reverse($parents) as $j) {
    $sides[$j]['right'] = ++$s;
}

这是我实际代码的过度简化版本,因为它只是将“side”值存储在一个单独的数组中,但它演示了原理。
基本思想是将所有父节点(由深度值跟踪)存储在一个数组中,并且只在循环中写入“左”值。然后,当深度减小时,意味着您已经返回到层次结构中,因此父数组将被拼接以删除不再相关的数组,并且它们将循环(反向)设置“右”值。最后,你必须在最后把剩下的父母圈起来。

08-06 16:36