【问题标题】:PHP RecursiveIteratorIterator and nested setsPHP RecursiveIteratorIterator 和嵌套集
【发布时间】:2010-10-05 19:16:38
【问题描述】:

我在层次结构中有一组对象。有一个顶部的“根”节点,它有子节点,子节点又具有子节点等。我正在尝试使用嵌套集模型将此结构保存到数据库中,其中每个节点的每个“边”都被编号以定义层次结构,如Managing Hierarchical Data in MySQL:


(来源:mysql.com

我的问题是计算左右值。我通常使用 RecursiveIteratorIterator 来遍历层次结构,但如果不求助于通过引用解析索引变量的递归函数,我无法弄清楚如何计算数字。

有什么想法吗?

这可能没用,但这是我目前拥有的(不正确的)代码:

$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)

【问题讨论】:

    标签: php recursion iterator nested-sets


    【解决方案1】:

    没有递归是不可能解决这个问题的。您需要以下内容:

    function tag_recursive($node, &$number) {
        $node->left = $number++;
        foreach ($node->children as &$child) {
            tag_recursive($child, $number);
        }
        $node->right = $number++;
    }
    
    function tag($node) {
        $number = 1;
        tag_recursive($node, $number);
        // $number is now highest id + 1
    }
    

    【讨论】:

      【解决方案2】:

      我想通了,这是解决方案(简化):

      $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;
      }
      

      这是我实际代码的简化版本,因为它只是将“边”值存储在一个单独的数组中,但它演示了原理。

      基本思想是将所有父节点(由深度值跟踪)存储在一个数组中,并且只在循环中写入“左”值。然后,当深度减小时,这意味着您已经返回层次结构,因此父数组被拼接以删除不再相关的数组,并且它们被循环(反向)设置“正确”值。最后,您必须在最后循环剩余的父母。

      【讨论】:

        猜你喜欢
        • 2013-08-01
        • 2012-06-02
        • 1970-01-01
        • 2011-04-28
        • 1970-01-01
        • 1970-01-01
        • 2017-03-08
        • 1970-01-01
        • 2017-01-04
        相关资源
        最近更新 更多