opmvpc / constructs
Data structures
Installs: 6
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 1
pkg:composer/opmvpc/constructs
Requires
- php: >=7.2
- symfony/var-dumper: ^4.3
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.16
- nunomaduro/phpinsights: ^1.7
- phpunit/phpunit: ^8.5
- vimeo/psalm: ^3.11
This package is auto-updated.
Last update: 2025-10-06 01:37:01 UTC
README
Constructs
Constructs provides simple data structures with a fluent api.
- Install
- Lists
- ArrayList
- LinkedList
- Stacks
- ArrayStack
- LinkedStack
- Queues
- ArrayQueue
- Threes
- ArrayHeap
- SearchThree
- Helpers
- toArray()
- dump() & dumpAndDie()
🛠 Install
Just add this package to your composer project:
$ composer require opmvpc/constructs
Then import Constructs main class or individual classes in your code.
Lists
Available methods
public static function make(): ListContract; public function size(): int; public function contains($item): bool; public function add($item): ListContract; public function remove($item): ListContract; public function get(int $i); public function toArray(): array;
ArrayList
Usage
$list = Construct::arrayList() ->add(4) ->add(2) ->remove(4) ->add(6);
LinkedList
Usage
$list = Construct::linkedList() ->add(4) ->add(2) ->add(6);
Complexity
| Method | ArrayList | LinkedList |
|---|---|---|
| get() | O(1) | O(n) |
| add() | O(1) | O(1) |
| remove() | O(n) | O(n) |
Stacks
Available methods
public static function make(): StackContract; public function isEmpty(): bool; public function push($item): StackContract; public function pop(): StackContract; public function top(); public function toArray(): array;
ArrayStack
Usage
$stack = Construct::linkedStack() ->push(4) ->push(2) ->pop();
LinkedStack
Usage
$stack = Construct::linkedStack() ->push(4) ->push(2) ->pop();
Complexity
| Method | ArrayStack | LinkedStack |
|---|---|---|
| isEmpty() | O(1) | O(1) |
| push() | O(1) | O(1) |
| pop() | O(1) | O(1) |
Queues
Available methods
public static function make(): QueueContract; public function isEmpty(): bool; public function enqueue($item): QueueContract; public function dequeue(); public function peek(); public function toArray(): array;
ArrayQueue
Usage
$queue = Construct::linkedQueue() ->enqueue(4) ->enqueue(2) ->dequeue() ->enqueue(6);
Complexity
| Method | ArrayQueue | LinkedQueue |
|---|---|---|
| isEmpty() | O(1) | O(1) |
| push() | O(1) | O(1) |
| pop() | O(1) | O(1) |
Threes
ArrayHeap
Available methods
public static function make(): ThreeContract; public function size(): int; public function add($item): ThreeContract; public function remove($item): ThreeContract; public function get(int $i): SimpleNode; public function toArray(): array;
Usage
$heap = Construct::arrayHeap() ->add(4) ->add(2) ->remove(2) ->add(6);
Complexity
| Method | ArrayHeap | LinkedHeap |
|---|---|---|
| get() | O(1) | O(nlog(n)) |
| add() | O(nlog(n)) | O(nlog(n)) |
| remove() | O(nlog(n)) | O(nlog(n)) |
LinkedSearchThree
Available methods
public static function make(): ThreeContract; public function root(): Leaf; public function min(): Leaf; public function max(): Leaf; public function search($key): Leaf; public function insert($index, $item): ThreeContract; public function toArray(): array; public function keysArray(): array;
Usage
$three = Construct::arrayHeap() ->insert(4, 'world') ->insert(2, 'hello'); $three->min(); $three->max();
Algorithmic Complexity
| Method | ArraySearchThree | LinkedSearchThree |
|---|---|---|
| search() | O(2ⁿ) | O(h) |
| insert() | O(2ⁿ) | O(h) |
| remove() | O(2ⁿ) | O(h) |
Space Complexity
| Type | Space complexity |
|---|---|
| ArraySearchThree | O(2ⁿ) |
| LinkedSearchThree | O(n) |
Helpers
toArray()
You can get an array representation of the current structure with the toArray() method.
$array = Construct::linkedList() ->add(4) ->toArray();
dump() 🚽 & dumpAndDie() ☠
Constructs uses the var_dumper Symfony component. You can use the dump() method on your structures.
$list = Construct::linkedList() ->add(4) ->dump() ->remove(4) ->dump();
If you are more a "Dump and die" person, dumpAndDie() method is also available.
$list = Construct::linkedList() ->add(4) ->add(2) ->remove(4) ->add(6) ->dumpAndDie();