Avoid collision using linear probing
Collision
While hashing, two or more key points to the same hash index under some modulo M is called as collision.
In this tutorial, we will learn how to avoid collison using linear probing technique.
Linear Probing
Calculate the hash key. key = data % size;
If hashTable[key] is empty, store the value directly. hashTable[key] = data.
If the hash index already has some value, check for next index.
key = (key+1) % size;
If the next index is available hashTable[key], store the value. Otherwise try for next index.
Do the above process till we find the space.
Linear Probing Procedure
Initial Hash Table
data:image/s3,"s3://crabby-images/96888/968888ce7bfe5bbe8f9f790dca1428c5948decf7" alt="Hash Bucket"
Insert 13
data:image/s3,"s3://crabby-images/13ced/13ced9d04dab7ef47e6944cf9e38d84ace792e2e" alt="Linear Probing Example 1"
insert 1
data:image/s3,"s3://crabby-images/b9d60/b9d60aa50e8ad67a65c724d30cea137e476da6de" alt="Linear Probing Example 2"
Insert 6
data:image/s3,"s3://crabby-images/e89ec/e89ecad0afefa2051fc14f9d4b991200e6fd1857" alt="Linear Probing Example 3"
1 % 5 = 1.
6 % 5 = 1.
Both 1 and 6 points the same index under modulo 5.
So that we have placed 6 in arr[2] which is next available index.
Insert 11
data:image/s3,"s3://crabby-images/804e1/804e1fbe1c1416983dfbd4a828d057fc95c42725" alt="Linear Probing Example 4"
1 % 5 = 1.
6 % 5 = 1.
11 % 5 = 1.
Both 1, 6 and 11 points the same index under modulo 5.
So that we have placed 11 in arr[4] which is next available index.
Insert 10
data:image/s3,"s3://crabby-images/52e7f/52e7fe300f674e31c4541154040b051421b44efc" alt="Linear Probing Example 5"
Insert 15
data:image/s3,"s3://crabby-images/2424e/2424e8c652f88ca48c77554f5c8f19ae5d93640d" alt="Linear Probing Example 6"
15 % 5 = 0.
Hash table don't have any empty index. So, we can't insert the data.