mirror of
https://github.com/TheAlgorithms/PHP.git
synced 2025-07-07 18:22:27 +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 * updating DIRECTORY.md * 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() * Implemented Splay Tree Data Structure * Update tests/DataStructures/SplayTreeTest.php Co-authored-by: Brandon Johnson <bbj1979@gmail.com> * Implemented Trie Data Structure. Added case-insensitive feature to the Trie implementation. Added corresponding unit testing. --------- Co-authored-by: Brandon Johnson <bbj1979@gmail.com> Co-authored-by: Ramy-Badr-Ahmed <Ramy-Badr-Ahmed@users.noreply.github.com>
64 lines
1.5 KiB
PHP
64 lines
1.5 KiB
PHP
<?php
|
|
|
|
/*
|
|
* Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) in Pull Request #162 and #172
|
|
* https://github.com/TheAlgorithms/PHP/pull/162
|
|
* https://github.com/TheAlgorithms/PHP/pull/172
|
|
*
|
|
* Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request addressing bugs/corrections to this file.
|
|
* Thank you!
|
|
*/
|
|
|
|
namespace DataStructures\Trie;
|
|
|
|
class TrieNode
|
|
{
|
|
/** @var array<string, TrieNode> */
|
|
public array $children;
|
|
public bool $isEndOfWord;
|
|
|
|
public function __construct()
|
|
{
|
|
$this->children = []; // Associative array where [ char => TrieNode ]
|
|
$this->isEndOfWord = false;
|
|
}
|
|
|
|
/**
|
|
* Add a child node for a character.
|
|
*/
|
|
public function addChild(string $char): TrieNode
|
|
{
|
|
$char = $this->normalizeChar($char);
|
|
if (!isset($this->children[$char])) {
|
|
$this->children[$char] = new TrieNode();
|
|
}
|
|
return $this->children[$char];
|
|
}
|
|
|
|
/**
|
|
* Check if a character has a child node.
|
|
*/
|
|
public function hasChild(string $char): bool
|
|
{
|
|
$char = $this->normalizeChar($char);
|
|
return isset($this->children[$char]);
|
|
}
|
|
|
|
/**
|
|
* Get the child node corresponding to a character.
|
|
*/
|
|
public function getChild(string $char): ?TrieNode
|
|
{
|
|
$char = $this->normalizeChar($char);
|
|
return $this->children[$char] ?? null;
|
|
}
|
|
|
|
/**
|
|
* Normalize the character to lowercase.
|
|
*/
|
|
private function normalizeChar(string $char): string
|
|
{
|
|
return strtolower($char);
|
|
}
|
|
}
|