/** * File: simple_hash.dart * Created Time: 2023-06-25 * Author: liuyuxin (gvenusleo@gmail.com) */ /* Additive hash */ int addHash(String key) { int hash = 0; final int MODULUS = 1000000007; for (int i = 0; i < key.length; i++) { hash = (hash + key.codeUnitAt(i)) % MODULUS; } return hash; } /* Multiplicative hash */ int mulHash(String key) { int hash = 0; final int MODULUS = 1000000007; for (int i = 0; i < key.length; i++) { hash = (31 * hash + key.codeUnitAt(i)) % MODULUS; } return hash; } /* XOR hash */ int xorHash(String key) { int hash = 0; final int MODULUS = 1000000007; for (int i = 0; i < key.length; i++) { hash ^= key.codeUnitAt(i); } return hash & MODULUS; } /* Rotational hash */ int rotHash(String key) { int hash = 0; final int MODULUS = 1000000007; for (int i = 0; i < key.length; i++) { hash = ((hash << 4) ^ (hash >> 28) ^ key.codeUnitAt(i)) % MODULUS; } return hash; } /* Dirver Code */ void main() { String key = "Hello algorithm"; int hash = addHash(key); print("Additive hash value = $hash"); hash = mulHash(key); print("Multiplicative hash value = $hash"); hash = xorHash(key); print("XOR hash value = $hash"); hash = rotHash(key); print("Rotational hash value = $hash"); }