ryvova / linkedlist
SortedLinkedListPackage
Requires
- php: >=8.2
- ext-intl: *
Requires (Dev)
- phpstan/phpstan: ^1.11.0
- phpunit/phpunit: ^9
This package is not auto-updated.
Last update: 2025-01-14 17:08:24 UTC
README
Do you really use linked lists? I met them at the grammar school in the 1st year of programming lessons in 1986 and I haven't needed them since. Even then, I thought it was a terribly stupid thing, because:
- It is terribly slow to access the value in the middle of the list (it has to be traversed step-by-step) unlike, for example, an array.
- In addition, it is also memory-intensive due to the need to store a link to the next (eventually previous) element.
- Low instruction level parallelism - while traversing a linkded list, the CPU doesn't have a lot of work to do because it cannot start processing the next node until it has finished loading the current node.
I used a two-way linked list.
- The advantage are:
- It makes it easier and faster to delete the last element of the list (I don't have to loop through the whole list).
- if I know, for example, that the data in the sorted list has a normal distribution, I can adjust the method for adding/deleting so that when the min. value 1, max 10000 and I will want to insert/delete 7000, so I will traverse from back to front.
- The disadvantage is: A higher memory requirement (each node must contain a link not only to the next one, but also to the previous one).
To decide whether to choose a one-way/two-way linked list and whether to sort it in ascending/descending order, it would be necessary to know more about:
- What it is to be used for,
- How the data that will be filled into it will look like, if, for example, the data will go in sorted order, than we can modify add to add to the beginning/end,
- How important is time or memory consumption etc.
When merging two lists, I use the fact that they are both sorted. Of course, I could call the add() method on each element of the list being added, which would go through the first list from the beginning and put it in the right place. Since they are both sorted, I just need to remember the pointer to where I added the element in the list I'm adding to and continue from there.
The assignment does not specify how the lists with string values should be sorted. I use sort by system settings. Since int values are compared using </=/> and string values using compare, I modified function compare so that it can also compare int values so that I don't have to find out what type the values are every time. Perhaps it would be more efficient to simply retype int to string and then use the compare.
It would be worth considering that the Node contains not only the value, but also the number of times the value occurs. It would simplify adding and removing nodes - it would only be enough to increment/decrement the number and pointers would not have to be solved (unless all Nodes with a given value were deleted).
In practice, where the library would be part of a larger project, it would be advisable to consider whether the collator should be made as a singleton, since its settings would always be the same according to the system.
I use the __toString() methods to clearly display information about lists for testing purposes (var_dump objects with pointers is very confusing). I want to be sure that the code is functional, so I wrote unit tests for it.
It is worth considering whether to make the list immutable - after creation, set a flag to it and during further processing check whether there has been a change.
Since you say you use your own rules for PHPStan, I also ran the code through PHPStan level 9.
I never use recursion due to extreme memory requirements. I wanted to be sure that the code works, so I also wrote PHPUnit tests for the methods. It should be a libraty, so I registered the code as a package on packagist.org as ryvova/linkedlist