/* * File: simple_hash.rs * Created Time: 2023-09-07 * Author: night-cruise (2586447362@qq.com) */ /* Additive hash */ fn add_hash(key: &str) -> i32 { let mut hash = 0_i64; const MODULUS: i64 = 1000000007; for c in key.chars() { hash = (hash + c as i64) % MODULUS; } hash as i32 } /* Multiplicative hash */ fn mul_hash(key: &str) -> i32 { let mut hash = 0_i64; const MODULUS: i64 = 1000000007; for c in key.chars() { hash = (31 * hash + c as i64) % MODULUS; } hash as i32 } /* XOR hash */ fn xor_hash(key: &str) -> i32 { let mut hash = 0_i64; const MODULUS: i64 = 1000000007; for c in key.chars() { hash ^= c as i64; } (hash & MODULUS) as i32 } /* Rotational hash */ fn rot_hash(key: &str) -> i32 { let mut hash = 0_i64; const MODULUS: i64 = 1000000007; for c in key.chars() { hash = ((hash << 4) ^ (hash >> 28) ^ c as i64) % MODULUS; } hash as i32 } /* Driver Code */ fn main() { let key = "Hello algorithm"; let hash = add_hash(key); println!("Additive hash value is {hash}"); let hash = mul_hash(key); println!("Multiplicative hash value is {hash}"); let hash = xor_hash(key); println!("XOR hash value is {hash}"); let hash = rot_hash(key); println!("Rotational hash value is {hash}"); }