Hashing
Hashing is an efficient method to store and retrieve elements.
It’s exactly same as index page of a book. In index page, every topic is associated with a page number. If we want to look some topic, we can directly get the page number from the index.
Likewise, in hashing every value will be associated with a key. Using this key, we can point out the element directly.
Let’s discuss hashing with modulo method.
How to calculate the hash key?
Let's take hash table size as 7.
size = 7
arr[size];
Formula to calculate key is,
key = element % size
If we take modulo of number with N, the remainder will always be 0 to N - 1.
Exactly array index also starts from 0 and ends with index N -1. So we can easily store elements in array index.
Initialize the Hash Bucket
Before inserting elements into array. Let’s make array default value as -1.
-1 indicates element not present or the particular index is available to insert.
data:image/s3,"s3://crabby-images/dddf8/dddf89f195a36dca632fe45b9a392775c8de7991" alt="Hash Bucket"
Inserting elements in the hash table
i)insert 24
data:image/s3,"s3://crabby-images/c7f64/c7f64fcb4546a5925720a9bbed21dafea1079183" alt="Inserting elements into the hash table."
ii)insert 8
data:image/s3,"s3://crabby-images/f0921/f09217e103d217d1755e441c708c016e8be16947" alt="Inserting elements into the hash table."
iii)insert 14
data:image/s3,"s3://crabby-images/609cd/609cdc1d231411236558e0683b99ad8a8ac21916" alt="Inserting elements into the hash table."
Searching elements from the hash table
i)search 8
data:image/s3,"s3://crabby-images/06b96/06b96bbe31a03601d457813ab1a0f174ace020b9" alt="Searching elements from the hash table."
ii)search 19
data:image/s3,"s3://crabby-images/6f428/6f4284762b151282eaa34fbf94343f6542a37f00" alt="Searching elements from the hash table."
Deleting an element from the hash table
Here, we are not going to remove the element.
We just mark the index as -1. It is indirectly delete the element from array.
Example
Delete: 24
data:image/s3,"s3://crabby-images/67973/6797338fd939b46efa8f992d6bd0c52c6f1d1c24" alt="Deleting an element from the hash table"
What is collision in hashing?
What if we insert an element say 15 to existing hash table?
Insert : 15
Key = element % key
Key = 15 % 7
Key = 1
But already arr[1] has element 8 !
Here, two or more different elements pointing to the same index under modulo size. This is called collision.
data:image/s3,"s3://crabby-images/c04b1/c04b1212439e9f803d9b75afc0933ba163993e79" alt="collision in hashing"
Hash table implementation in c using arrays
Example
#include<stdio.h> #define size 7 int arr[size]; void init() { int i; for(i = 0; i < size; i++) arr[i] = -1; } void insert(int value) { int key = value % size; if(arr[key] == -1) { arr[key] = value; printf("%d inserted at arr[%d]\n", value,key); } else { printf("Collision : arr[%d] has element %d already!\n",key,arr[key]); printf("Unable to insert %d\n",value); } } void del(int value) { int key = value % size; if(arr[key] == value) arr[key] = -1; else printf("%d not present in the hash table\n",value); } void search(int value) { int key = value % size; if(arr[key] == value) printf("Search Found\n"); else printf("Search Not Found\n"); } void print() { int i; for(i = 0; i < size; i++) printf("arr[%d] = %d\n",i,arr[i]); } int main() { init(); insert(10); //key = 10 % 7 ==> 3 insert(4); //key = 4 % 7 ==> 4 insert(2); //key = 2 % 7 ==> 2 insert(3); //key = 3 % 7 ==> 3 (collision) printf("Hash table\n"); print(); printf("\n"); printf("Deleting value 10..\n"); del(10); printf("After the deletion hash table\n"); print(); printf("\n"); printf("Deleting value 5..\n"); del(5); printf("After the deletion hash table\n"); print(); printf("\n"); printf("Searching value 4..\n"); search(4); printf("Searching value 10..\n"); search(10); return 0; }
We didn't implement any collision avoidance technique in the above code.
We will discuss collision avoidance in the next tutorials.
Collision Avoidance
Collision Avoidance using Linear ProbingCollision Avoidance using Separate Chaining