- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在层次结构中有一组对象。有一个顶级“根”节点,它有子节点,子节点又有子节点等。我正在尝试使用嵌套集模型将这个结构保存到数据库中,其中每个节点的每个“边”都被编号以定义层次结构,如 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)
最佳答案
我想通了,这是解决方案(简化):
$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;
}
这是我实际代码的过度简化版本,因为它只是将“边”值存储在一个单独的数组中,但它演示了原理。
基本思想是将所有父节点(由深度值跟踪)存储在一个数组中,并且只在循环中写入“左”值。然后,当深度减小时,这意味着您已经回到层次结构中,因此拼接父数组以删除不再相关的数组,然后循环(反向)设置“正确”值。最后,您必须在最后循环遍历其余的父级。
关于PHP RecursiveIteratorIterator 和嵌套集合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/517998/
我有以下: 到目前为止一切顺利,但我需要反转结果,以存档与 array_reverse() 相同的效果 我试过这样,没有成功: 另外,我怎样才能获得返回的结果数?我试过了,但没有用: 谁能帮帮我
我有以下多维数组: $array = array( 1 => null, 2 => array( 3 => null, 4 => array( 5 => null,
我在层次结构中有一组对象。有一个顶级“根”节点,它有子节点,子节点又有子节点等。我正在尝试使用嵌套集模型将这个结构保存到数据库中,其中每个节点的每个“边”都被编号以定义层次结构,如 Managing
RecursiveIteratorIterator 如果在 while 循环之前没有调用 rewind() 则返回额外的结果 例子 $array = array("A","B","C"); $iter
您好,当我在名为 upload 的文件夹中列出文件时遇到问题,当有阿拉伯文文件时它显示 ���� ���� ������ $target = "upload"; $it
我目前有一个网站可以显示所有目录和子目录(在 MAC 操作系统上)所以我这里有代码 $Directory = new RecursiveDirectoryIterator('/'); $Iterato
我的问题是,当我使用 namespace 时,我无法使用标准 PHP 库的 RecursiveIteratorIterator 类。以下代码: 返回: PHP Fatal error: Uncaug
我正在使用 RecursiveIteratorIterator() 来探索我当前路径的子文件夹,但是通过这种方式探索了所有树,相反我只想探索我的 fodler 的直接子目录以查找文件。我怎么能告诉 R
我正在使用 RecursiveIteratorIterator() 来探索我当前路径的子文件夹,但是通过这种方式探索了所有树,相反我只想探索我的 fodler 的直接子目录以查找文件。我怎么能告诉 R
我使用 RecursiveIteratorIterator 遍历多维数组,并希望能够知道当前元素是否是其深度的最后一个子元素。我想过这个: $iterator = new RecursiveItera
我尝试了几种方法来在文件系统上使用 RecursiveIteratorIterator 忽略某些目录。 为了举例说明,我想忽略以下目录:/cache。 我的 Iterator 看起来像这样: //$d
怎么样RecursiveIteratorIterator工作? PHP 手册没有太多记录或解释。 IteratorIterator有什么区别和 RecursiveIteratorIterator ?
正如标题所说,当我实例化一个类时,我收到这条消息: Fatal error: Class 'Envato\RecursiveIteratorIterator' not found in C:\User
我需要列出文件夹及其子文件夹中的所有文件(具有特定扩展名)。我使用了 RecursiveIteratorIterator,如@Matthew 在 PHP list all files in direc
通过 SPL 迭代器递归扫描目录的标准方法是: $files = new RecursiveIteratorIterator( new RecursiveDirectoryIterator($
我正在使用这段代码,效果很好。然而,由于 foreach 的倍数,这似乎不是最佳选择。 foreach ($arr_items as $key => $value) { $id_user =
我必须缓存一个树结构并稍后访问它。问题:我真的不知道如何声明数据以使其适合 RecursiveIteratorIterator 等。这可能是一个非常 n00bish 的问题,但我尝试了很多组合并且没有
我需要从服务器获取文件和文件夹列表。 我不想一次获取所有文件、文件夹、子文件夹。 我想根据需要一点一点地得到他们的。所以我使用 AJAX。 我使用 PHP。我使用 RecursiveIteratorI
这是我的 php 脚本: $object){ echo $objects->getDepth() . " " . $object->getFilename() . ""; } ?
RecursiveIteratorIterator::next() 和 RecursiveIteratorIterator::nextElement() 有什么区别? 文档略有不足: Recursiv
我是一名优秀的程序员,十分优秀!