This commit is contained in:
krahets
2026-03-29 05:06:58 +08:00
parent 37523d4ceb
commit 967293c421
51 changed files with 288 additions and 5073 deletions
+4 -88
View File
@@ -601,13 +601,7 @@ index = hash(key) % capacity
=== "Ruby"
```ruby title="simple_hash.rb"
=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
@@ -617,23 +611,7 @@ index = hash(key) % capacity
hash % modulus
end
=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
@@ -643,33 +621,7 @@ index = hash(key) % capacity
hash % modulus
end
=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-хеширование ###
### XOR-хеширование ###
def xor_hash(key)
hash = 0
modulus = 1_000_000_007
@@ -679,43 +631,7 @@ index = hash(key) % capacity
hash % modulus
end
=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