| @@ 424-433 (lines=10) @@ | ||
| 421 | $this->_preorder($this->root, $callback); |
|
| 422 | } |
|
| 423 | ||
| 424 | private function _preorder($node, Callable $callback = null) { |
|
| 425 | if($node === null) { |
|
| 426 | return; |
|
| 427 | } |
|
| 428 | if($callback !== null) { |
|
| 429 | call_user_func($callback, $node); |
|
| 430 | } |
|
| 431 | $this->_preorder($node->left, $callback); |
|
| 432 | $this->_preorder($node->right, $callback); |
|
| 433 | } |
|
| 434 | ||
| 435 | /** |
|
| 436 | * Traverse in inorder. This is: first visit the left subtree, |
|
| @@ 443-453 (lines=11) @@ | ||
| 440 | $this->_inorder($this->root); |
|
| 441 | } |
|
| 442 | ||
| 443 | private function _inorder($node, Callable $callback = null) { |
|
| 444 | if($node === null) { |
|
| 445 | return; |
|
| 446 | } |
|
| 447 | ||
| 448 | $this->_inorder($node->left, $callback); |
|
| 449 | if($callback !== null) { |
|
| 450 | call_user_func($callback, $node); |
|
| 451 | } |
|
| 452 | $this->_inorder($node->right, $callback); |
|
| 453 | } |
|
| 454 | ||
| 455 | /** |
|
| 456 | * Traverse in postorder. This is: first visit the left subtree, |
|
| @@ 471-480 (lines=10) @@ | ||
| 468 | * @param Callable|null $callback the callback function to apply to each |
|
| 469 | * node. |
|
| 470 | */ |
|
| 471 | private function _postorder($node, Callable $callback = null) { |
|
| 472 | if($node === null) { |
|
| 473 | return; |
|
| 474 | } |
|
| 475 | $this->_postorder($node->left, $callback); |
|
| 476 | $this->_postorder($node->right, $callback); |
|
| 477 | if($callback !== null) { |
|
| 478 | call_user_func($callback, $node); |
|
| 479 | } |
|
| 480 | } |
|
| 481 | ||
| 482 | /** |
|
| 483 | * Binds to count() method. This is equal to make $this->tree->size(). |
|