Skip to main content

Sophisticate Hash Table

Project description

hashtbl

PyPI version License: MIT

This library was created to simplify the concept of a hash table and explain how it works in the background in a clear and simple way, especially for beginners in data structures.

Installation

You can install hashtbl via pip:

pip install hashtbl

Usage

from hashtbl import hashMap


x = hashMap(
    [
        ["key1", "value1"],
        ["key2", "value2"],
        ["key3", "value3"],
    ]
)


print(x)

Output

{"key1": "value1", "key2": "value2", "key3": "value3"}

You Can Show All Details

from hashtbl import hashMap


x = hashMap(
    [
        ["key1", "value1"],
        ["key2", "value2"],
        ["key3", "value3"],
    ],
    detail=True,
)


print(x)

Output

Hash function :
_____________

f(x) = ord(x) % N (Hash table capacity)

Example :
_______

N = 26

f("ABC") = ord("ABC") % 26 = (ord('A') + ord('B') + ord('C')) % 26 = (65 + 66 + 67) % 26 = 198 % 26 = 16

The value associated with the key "ABC" will be placed at index 16 in the hash table (array) with a capacity of 26.

Notes :
_____

- If a key has the same index as an existing key in the hash table, it will be placed after it because, in a hash table, each index is a linked list.

- If a key is duplicated in the hash table, the last value associated with this key will be saved.

Hash Table :
__________

╒════════╤════════════════════════════════╤══════════╕
│ Key       Hash function Output (Index)  Value    │
╞════════╪════════════════════════════════╪══════════╡
│ "key1"                              14  "value1" │
├────────┼────────────────────────────────┼──────────┤
│ "key2"                              15  "value2" │
├────────┼────────────────────────────────┼──────────┤
│ "key3"                              16  "value3" │
╘════════╧════════════════════════════════╧══════════╛

Advanced Usage

You Can See The Key/Value Pairs In The Linked List If There Is More Than One Key In One Index (Hash Function Output).

from hashtbl import hashMap


x = hashMap(
    [
        ["algorithm", "algo"],
        ["logarithm", "log"],
    ],
    detail=False,
)


# When the keys are 'algorithm' and 'logarithm', 5 is the output index of the hash function. You can view this index and all other key indexes by printing with all details (detail=True).
print(x.get_linked_list(5))

Output

[('algorithm', 'algo')] -> [('logarithm', 'log')] -> None (NULL)

You Can See It With All Details

from hashtbl import hashMap


x = hashMap(
    [
        ["algorithm", "algo"],
        ["logarithm", "log"],
    ],
    detail=True,
)


# When the keys are 'algorithm' and 'logarithm', 5 is the output index of the hash function. You can view this index and all other key indexes by printing with all details (detail=True).
print(x.get_linked_list(5))

Output

╒═══════════════════════╤═════════════════════════╤══════════════════════╤══════════════════════╕
│ Current Value          Current Value @ddress    Next Value            Next Value @ddress   │
╞═══════════════════════╪═════════════════════════╪══════════════════════╪══════════════════════╡
│ ('algorithm', 'algo')  0x7f527dd225d0           ('logarithm', 'log')  0x7f527dd21d50       │
├───────────────────────┼─────────────────────────┼──────────────────────┼──────────────────────┤
│ ('logarithm', 'log')   0x7f527dd21d50           None (NULL)           0x95bcc0 (nil/0x0)   │
├───────────────────────┼─────────────────────────┼──────────────────────┼──────────────────────┤
│ None (NULL)            0x95bcc0 (nil/0x0)                                                  │
╘═══════════════════════╧═════════════════════════╧══════════════════════╧══════════════════════╛

Note

You can use all methods of the built-in hash table (dictionary) with this custom hash table.

License

This project is licensed under the MIT LICENSE - see the LICENSE for more details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hashtbl-1.0.4.tar.gz (7.8 kB view hashes)

Uploaded Source

Built Distribution

hashtbl-1.0.4-py3-none-any.whl (6.8 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page