opmvpc / constructs
Data structures
1.0.1
2020-06-05 13:57 UTC
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-04-06 00:27:27 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();