A Quick Overview of Hash Tables
Combine all the different operations discussed previously and test out the functionality of your complete hash table class.
We'll cover the following...
Complete implementation
The previous lessons discussed each aspect of a hash table in detail. Below, you can find the complete hash table class:
Press + to interact
main.cs
Hash.cs
using System;namespace chapter_9{class HashEntry{public string key;public int value;public HashEntry next;// Constructorpublic HashEntry(){key = "";value = -1;next = null;}public HashEntry(string key, int value){this.key = key;this.value = value;next = null;}}// Class to represent entire hash tableclass HashTable{HashEntry [] bucket = null;int slots;int size;public HashTable(int s){bucket = new HashEntry[s];//Initialise all elements of array as NULLfor (int i = 0; i < s; i++)bucket[i] = null;slots = s;size = 0;}public int getSize(){return size;}public bool isEmpty(){return getSize() == 0;}public int getIndex(string key){//hashCode is a built in function of Strings//takes key and size of the listint Key = 0;for (int i = 0; i < key.Length; i++){Key = 37 * Key + key[i];}if (Key < 0)Key *= -1;return Key % slots;}public void insert(string key, int value){// Apply hash function to find index for given keyint hashIndex = getIndex(key);if (bucket[hashIndex] == null){bucket[hashIndex] = new HashEntry(key, value);size++;}else{ //find next free spaceHashEntry temp = bucket[hashIndex]; ;while (temp.next != null){temp = temp.next;}temp.next = new HashEntry(key, value);size++;}}public void display(){HashEntry temp;for (int i = 0; i < slots; i++){if (bucket[i] != null){Console.Write("HashIndex : " + i + " ");temp = bucket[i];while (temp != null){Console.Write( "(key = " + temp.key + " , value = " + temp.value + " )");temp = temp.next;}}Console.WriteLine("");}}public void resize(){Console.WriteLine("resize");slots *= 2;HashEntry [] tempBucket = new HashEntry[slots];int hashIndex;HashEntry tmp = null;for (int i = 0; i < slots; i++)tempBucket[i] = null;HashEntry temp = null;for (int i = 0; i < slots / 2; i++){if (bucket[i] != null){temp = bucket[i];while (temp != null){hashIndex = getIndex(temp.key);if (tempBucket[hashIndex] == null)tempBucket[hashIndex] = new HashEntry(temp.key, temp.value);else{ //find next free spacetmp = tempBucket[hashIndex]; ;while (tmp.next != null){tmp = tmp.next;}tmp.next = new HashEntry(temp.key, temp.value);}temp = temp.next;}}}bucket = tempBucket;}public int search(string key){int hashIndex = getIndex(key);if (bucket[hashIndex] == null){Console.WriteLine("Value Not Found!");return -1;}if (bucket[hashIndex].key == key){return bucket[hashIndex].value;}else{ //find next free spaceHashEntry temp = bucket[hashIndex];while (temp != null){if (temp.key == key){return temp.value;}temp = temp.next;}Console.WriteLine("Value Not Found!");return -1;}}public void Delete(string key){int hashIndex = getIndex(key);if (bucket[hashIndex] == null){Console.WriteLine("Value To Be Deleted Not Found!");return;}if (bucket[hashIndex].key == key){if (bucket[hashIndex].next != null){bucket[hashIndex] = bucket[hashIndex].next;}else{bucket[hashIndex] = null;}}else{ //find next free spaceHashEntry temp = bucket[hashIndex];HashEntry prev = bucket[hashIndex];while (temp != null){if (temp.key == key){if (temp.next != null){prev.next = temp.next;temp = temp.next;}elseprev.next = null;return;}prev = temp;temp = temp.next;}Console.WriteLine("Value to be deleted not Found!");}}}}
Overview
To sum up the ...