=begin File: simple_hash.rb Created Time: 2024-04-14 Author: Xuan Khoa Tu Nguyen (ngxktuzkai2000@gmail.com) =end ### Аддитивное хеширование ### def add_hash(key) hash = 0 modulus = 1_000_000_007 key.each_char { |c| hash += c.ord } hash % modulus end ### Мультипликативное хеширование ### def mul_hash(key) hash = 0 modulus = 1_000_000_007 key.each_char { |c| hash = 31 * hash + c.ord } hash % modulus end ### XOR-хеширование ### def xor_hash(key) hash = 0 modulus = 1_000_000_007 key.each_char { |c| hash ^= c.ord } hash % modulus end ### Хеширование с циклическим сдвигом ### def rot_hash(key) hash = 0 modulus = 1_000_000_007 key.each_char { |c| hash = (hash << 4) ^ (hash >> 28) ^ c.ord } hash % modulus end ### Driver Code ### if __FILE__ == $0 key = "Hello Algo" hash = add_hash(key) puts "Хеш-сумма сложением = #{hash}" hash = mul_hash(key) puts "Хеш-сумма умножением = #{hash}" hash = xor_hash(key) puts "Хеш-сумма XOR = #{hash}" hash = rot_hash(key) puts "Хеш-сумма с циклическим сдвигом = #{hash}" end