mirror of
https://github.com/TheAlgorithms/PHP.git
synced 2025-07-09 11:13:50 +02:00
* 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 Trie DataStructure * Added Trie to DIRECTORY.md * updating DIRECTORY.md * Implemented AVLTree DataStructure * updating DIRECTORY.md * Implemented AVLTree DataStructure * Implemented SegmentTreeNode.php * Implementing SegmentTree * Implementing SegmentTree with updateTree * Implementing SegmentTree with rangeUpdateTree * Implementing SegmentTree with query and queryTree * Added serializing and deserializing of the SegmentTree * Adding unit tests SegmentTree implementation * Added unit tests for SegmentTree updates and range updates * considering PHPCS for Added unit tests for SegmentTree updates and range updates * Added unit tests for SegmentTree serialization/deserialization and array updates reflections * Added unit tests for SegmentTree Edge Cases * Added unit tests for SegmentTree Exceptions (OutOfBoundsException, InvalidArgumentException) * Added SegmentTree to DIRECTORY.md * Implemented Segment Tree Data Structure * Added some comments to my files in: #160, #162, #163, #166. Implemented Segment Tree Data Structure. * Added some comments to my files in: #160, #162, #163, #166. Implemented Segment Tree Data Structure. * Added comments time complexity for query(), update() and buildTree() --------- Co-authored-by: Brandon Johnson <bbj1979@gmail.com> Co-authored-by: Ramy-Badr-Ahmed <Ramy-Badr-Ahmed@users.noreply.github.com>
50 lines
1.3 KiB
PHP
50 lines
1.3 KiB
PHP
<?php
|
|
|
|
/*
|
|
* Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) in Pull Request: #163
|
|
* https://github.com/TheAlgorithms/PHP/pull/163
|
|
*
|
|
* Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request addressing bugs/corrections to this file.
|
|
* Thank you!
|
|
*/
|
|
|
|
namespace DataStructures\AVLTree;
|
|
|
|
class AVLTreeNode
|
|
{
|
|
/**
|
|
* @var int|string
|
|
*/
|
|
public $key;
|
|
/**
|
|
* @var mixed
|
|
*/
|
|
public $value;
|
|
public ?AVLTreeNode $left;
|
|
public ?AVLTreeNode $right;
|
|
public int $height;
|
|
|
|
public function __construct($key, $value, ?AVLTreeNode $left = null, ?AVLTreeNode $right = null)
|
|
{
|
|
$this->key = $key;
|
|
$this->value = $value;
|
|
$this->left = $left;
|
|
$this->right = $right;
|
|
$this->height = 1; // New node is initially at height 1
|
|
}
|
|
|
|
public function updateHeight(): void
|
|
{
|
|
$leftHeight = $this->left ? $this->left->height : 0;
|
|
$rightHeight = $this->right ? $this->right->height : 0;
|
|
$this->height = max($leftHeight, $rightHeight) + 1;
|
|
}
|
|
|
|
public function balanceFactor(): int
|
|
{
|
|
$leftHeight = $this->left ? $this->left->height : 0;
|
|
$rightHeight = $this->right ? $this->right->height : 0;
|
|
return $leftHeight - $rightHeight;
|
|
}
|
|
}
|