This method maintains a chain of elements that have the same hash address. We can take the hash table as an array of pointers. The size of the hash table can be the number of records. Here each pointer will point to one linked list and the elements which have the same hash address will be maintained in the linked list. We can maintain the linked list in sorted order and each element of the linked list will contain the whole record with a key.
- For inserting one element, first, we have to get the hash value through the hash function which will map in the hash table, then that element will be inserted in the linked list which is shown in the following Figure as an example.
- Searching for a key is also the same, first, we will get the hash key value in a hash table through the hash function, then we will search for the element in the corresponding linked list.
- Deletion of a key contains the first search operation then the same as the delete operation in the linked list.
The main advantage of this hashing is saving memory space and perfect collision resolution. Here hash table contains only pointers that point to the linked list, containing records. So there is no wastage of memory space because of an empty hash table and the hash table size can be taken as a number of records. Hash table space is also minimized because records are stored in the linked list. The elements which have the same hash address will be in the same linked list. So we should use a good hash function that distributes elements on different hash addresses. Basically linked lists will be small, so searching will be fast.
The main disadvantage is also a waste of memory space. In cases where records are very small or contain only a key then the link part for every element in the linked list and pointer space in the hash table will be a waste of memory space.
Source code
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.