/** * File: array_hash_map.cs * Created Time: 2022-12-23 * Author: haptear (haptear@hotmail.com) */ namespace hello_algo.chapter_hashing; /* Key-value pair int->string */ class Pair(int key, string val) { public int key = key; public string val = val; } /* Hash table based on array implementation */ class ArrayHashMap { List buckets; public ArrayHashMap() { // Initialize an array, containing 100 buckets buckets = []; for (int i = 0; i < 100; i++) { buckets.Add(null); } } /* Hash function */ int HashFunc(int key) { int index = key % 100; return index; } /* Query operation */ public string? Get(int key) { int index = HashFunc(key); Pair? pair = buckets[index]; if (pair == null) return null; return pair.val; } /* Add operation */ public void Put(int key, string val) { Pair pair = new(key, val); int index = HashFunc(key); buckets[index] = pair; } /* Remove operation */ public void Remove(int key) { int index = HashFunc(key); // Set to null, indicating removal buckets[index] = null; } /* Get all key-value pairs */ public List PairSet() { List pairSet = []; foreach (Pair? pair in buckets) { if (pair != null) pairSet.Add(pair); } return pairSet; } /* Get all keys */ public List KeySet() { List keySet = []; foreach (Pair? pair in buckets) { if (pair != null) keySet.Add(pair.key); } return keySet; } /* Get all values */ public List ValueSet() { List valueSet = []; foreach (Pair? pair in buckets) { if (pair != null) valueSet.Add(pair.val); } return valueSet; } /* Print hash table */ public void Print() { foreach (Pair kv in PairSet()) { Console.WriteLine(kv.key + " -> " + kv.val); } } } public class array_hash_map { [Test] public void Test() { /* Initialize hash table */ ArrayHashMap map = new(); /* Add operation */ // Add key-value pair (key, value) to the hash table map.Put(12836, "Ha"); map.Put(15937, "Luo"); map.Put(16750, "Suan"); map.Put(13276, "Fa"); map.Put(10583, "Ya"); Console.WriteLine("\nAfter adding, the hash table is\nKey -> Value"); map.Print(); /* Query operation */ // Enter key to the hash table, get value string? name = map.Get(15937); Console.WriteLine("\nEnter student ID 15937, found name " + name); /* Remove operation */ // Remove key-value pair (key, value) from the hash table map.Remove(10583); Console.WriteLine("\nAfter removing 10583, the hash table is\nKey -> Value"); map.Print(); /* Traverse hash table */ Console.WriteLine("\nTraverse key-value pairs Key->Value"); foreach (Pair kv in map.PairSet()) { Console.WriteLine(kv.key + " -> " + kv.val); } Console.WriteLine("\nIndividually traverse keys Key"); foreach (int key in map.KeySet()) { Console.WriteLine(key); } Console.WriteLine("\nIndividually traverse values Value"); foreach (string val in map.ValueSet()) { Console.WriteLine(val); } } }