Hashing is a technique that is used to uniquely identify a specific object from a group of similar objects. Suppose an object is to be assigned a key to it to make searching easy. To store the key/value pair, one can use a simple array like a data structure where keys (integers) can be used directly as an index to store values. However, in cases where the keys are large and cannot be used directly as an index, one should use hashing. In hashing, large keys are converted into small keys by using hash functions. The values are then stored in a data structure called hash table. Linear Probing, It may happen that the hashing technique is used to create an already used index of the array. In such a case, we can search for the next empty location in the array by looking into the next cell until we find an empty cell. This technique is called linear probing.Â
There are three basic operations linked with linear probing which are as follows:
- Search
- Insert
- Delete
Implementation: Hash tables with linear probing by making a helper class and testing this in the main class.
Example
Java
| // Java Program to Implement Hash Tables with Linear Probing  // Importing all classes from// java.util package// Importing all input output classesimportjava.io.*;importjava.util.*;// Importing Scanner class as in do-while// inputs are entered at run-time when// menu is popped to user to perform desired actionimportjava.util.Scanner;  // Helper class - LinearProbingHashTableclassLinearProbingHashTable {    // Member variables of this class    privateintcurrentSize, maxSize;    privateString[] keys;    privateString[] vals;      // Constructor of this class    publicLinearProbingHashTable(intcapacity)    {        currentSize = 0;        maxSize = capacity;        keys = newString[maxSize];        vals = newString[maxSize];    }      // Method 1    // Function to clear hash table    publicvoidmakeEmpty()    {        currentSize = 0;        keys = newString[maxSize];        vals = newString[maxSize];    }      // Method 2    // Function to get size of hash table    publicintgetSize() { returncurrentSize; }      // Method 3    // Function to check if hash table is full    publicbooleanisFull()    {        returncurrentSize == maxSize;    }      // Method 4    // Function to check if hash table is empty    publicbooleanisEmpty() { returngetSize() == 0; }      // Method 5    // Function to check if hash table contains a key    publicbooleancontains(String key)    {        returnget(key) != null;    }      // Method 6    // Function to get hash code of a given key    privateinthash(String key)    {        returnkey.hashCode() % maxSize;    }      // Method 7    // Function to insert key-value pair    publicvoidinsert(String key, String val)    {        inttmp = hash(key);        inti = tmp;          // Do-while loop        // Do part for performing actions        do{            if(keys[i] == null) {                keys[i] = key;                vals[i] = val;                currentSize++;                return;            }              if(keys[i].equals(key)) {                vals[i] = val;                return;            }              i = (i + 1) % maxSize;          }          // Do-while loop        // while part for condition check        while(i != tmp);    }      // Method 8    // Function to get value for a given key    publicString get(String key)    {        inti = hash(key);        while(keys[i] != null) {            if(keys[i].equals(key))                returnvals[i];            i = (i + 1) % maxSize;        }        returnnull;    }      // Method 9    // Function to remove key and its value    publicvoidremove(String key)    {        if(!contains(key))            return;          // Find position key and delete        inti = hash(key);        while(!key.equals(keys[i]))            i = (i + 1) % maxSize;        keys[i] = vals[i] = null;          // rehash all keys        for(i = (i + 1) % maxSize; keys[i] != null;             i = (i + 1) % maxSize) {            String tmp1 = keys[i], tmp2 = vals[i];            keys[i] = vals[i] = null;            currentSize--;            insert(tmp1, tmp2);        }        currentSize--;    }      // Method 10    // Function to print HashTable    publicvoidprintHashTable()    {        System.out.println("\nHash Table: ");        for(inti = 0; i < maxSize; i++)            if(keys[i] != null)                System.out.println(keys[i] + " "+ vals[i]);        System.out.println();    }}  // Main testing class// Main Class for LinearProbingHashTableTestpublicclassGFG {    // Main driver method    publicstaticvoidmain(String[] args)    {        // Creating a scanner object        // to take input from user        Scanner scan = newScanner(System.in);          // Display messages        System.out.println("Hash Table Test\n\n");        System.out.println("Enter size");          // maxSizeake object of LinearProbingHashTable        LinearProbingHashTable lpht            = newLinearProbingHashTable(scan.nextInt());          charch;          // Do-while loop        // Do part for performing actions        do        // Menu is displayed        // LinearProbingHashTable operations performed as        // per keys Users enter 'y' to continue 'n' if        // entered by user , the program terminates          {            // Menu            // Display messages            System.out.println("\nHash Table Operations\n");            System.out.println("1. insert ");            System.out.println("2. remove");            System.out.println("3. get");            System.out.println("4. clear");            System.out.println("5. size");              // Reading integer using nextInt()            intchoice = scan.nextInt();              // Switch case            switch(choice) {              // Case 1            case1:                  // Display message                System.out.println("Enter key and value");                lpht.insert(scan.next(), scan.next());                // Break statement to terminate a case                break;              // Case 2            case2:                  // Display message                System.out.println("Enter key");                lpht.remove(scan.next());                // Break statement to terminate a case                break;              // Case 3            case3:                  // Print statements                System.out.println("Enter key");                System.out.println("Value = "                                   + lpht.get(scan.next()));                // Break statement to terminate a case                break;              // Case 4            case4:                  lpht.makeEmpty();                // Print statement                System.out.println("Hash Table Cleared\n");                // Break statement to terminate a case                break;              // Case 5            case5:                  // Print statement                System.out.println("Size = "                                   + lpht.getSize());                break;              // Default case            // Executed when mentioned switch cases are not            // matched            default:                // Print statement                System.out.println("Wrong Entry \n ");                // Break statement                break;            }              // Display hash table            lpht.printHashTable();              // Display message asking the user whether            // he/she wants to continue            System.out.println(                "\nDo you want to continue (Type y or n) \n");              // Reading character using charAt() method to            // fetch            ch = scan.next().charAt(0);        } while(ch == 'Y'|| ch == 'y');    }} | 
 
 
Output:Â
Â
Random action performed over Hash TableÂ
- Size is entered as : 5
- Two key-value pairs are inserted
- G 121
- F 212
- Later Hash table is cleared
Â


 
                                    








