Files
TheAlgorithms-PHP/DataStructures/AVLTree/TreeTraversal.php
Ramy e43b4bfec8 Implemented AVL Tree Data Structure (#163)
* Added Disjoint Sets Data structure

* Moved DisjointSetTest.php to  tests/DataStructures

* Update DataStructures/DisjointSets/DisjointSet.php

Co-authored-by: Brandon Johnson <bbj1979@gmail.com>

* Update DataStructures/DisjointSets/DisjointSetNode.php

Co-authored-by: Brandon Johnson <bbj1979@gmail.com>

* Update DataStructures/DisjointSets/DisjointSetNode.php

Co-authored-by: Brandon Johnson <bbj1979@gmail.com>

* Update tests/DataStructures/DisjointSetTest.php

Co-authored-by: Brandon Johnson <bbj1979@gmail.com>

* Update tests/DataStructures/DisjointSetTest.php

Co-authored-by: Brandon Johnson <bbj1979@gmail.com>

* Update tests/DataStructures/DisjointSetTest.php

Co-authored-by: Brandon Johnson <bbj1979@gmail.com>

* Considered PHPCS remarks. Unit Testing is now working.

* Remove data type mixed. Considered annotations for php7.4.

* Remove data type mixed. Considered annotations for php7.4.

* updating DIRECTORY.md

* Implemented AVLTree DataStructure

* Implemented AVLTree DataStructure

---------

Co-authored-by: Brandon Johnson <bbj1979@gmail.com>
Co-authored-by: Ramy-Badr-Ahmed <Ramy-Badr-Ahmed@users.noreply.github.com>
2024-09-17 23:07:12 -06:00

81 lines
2.2 KiB
PHP

<?php
namespace DataStructures\AVLTree;
abstract class TreeTraversal
{
/**
* Perform an in-order traversal of the subtree.
* Recursively traverses the subtree rooted at the given node.
*/
public static function inOrder(?AVLTreeNode $node): array
{
$result = [];
if ($node !== null) {
$result = array_merge($result, self::inOrder($node->left));
$result[] = [$node->key => $node->value];
$result = array_merge($result, self::inOrder($node->right));
}
return $result;
}
/**
* Perform a pre-order traversal of the subtree.
* Recursively traverses the subtree rooted at the given node.
*/
public static function preOrder(?AVLTreeNode $node): array
{
$result = [];
if ($node !== null) {
$result[] = [$node->key => $node->value];
$result = array_merge($result, self::preOrder($node->left));
$result = array_merge($result, self::preOrder($node->right));
}
return $result;
}
/**
* Perform a post-order traversal of the subtree.
* Recursively traverses the subtree rooted at the given node.
*/
public static function postOrder(?AVLTreeNode $node): array
{
$result = [];
if ($node !== null) {
$result = array_merge($result, self::postOrder($node->left));
$result = array_merge($result, self::postOrder($node->right));
$result[] = [$node->key => $node->value];
}
return $result;
}
/**
* Perform a breadth-first traversal of the AVL Tree.
*/
public static function breadthFirst(?AVLTreeNode $root): array
{
$result = [];
if ($root === null) {
return $result;
}
$queue = [];
$queue[] = $root;
while (!empty($queue)) {
$currentNode = array_shift($queue);
$result[] = [$currentNode->key => $currentNode->value];
if ($currentNode->left !== null) {
$queue[] = $currentNode->left;
}
if ($currentNode->right !== null) {
$queue[] = $currentNode->right;
}
}
return $result;
}
}