mirror of
https://hub.njuu.cf/TheAlgorithms/Python.git
synced 2023-10-11 13:06:12 +08:00
parent
ae9d0f9196
commit
55b3088e47
27
hashes/adler32.py
Normal file
27
hashes/adler32.py
Normal file
@ -0,0 +1,27 @@
|
||||
"""
|
||||
Adler-32 is a checksum algorithm which was invented by Mark Adler in 1995.
|
||||
Compared to a cyclic redundancy check of the same length, it trades reliability for speed (preferring the latter).
|
||||
Adler-32 is more reliable than Fletcher-16, and slightly less reliable than Fletcher-32.[2]
|
||||
|
||||
source: https://en.wikipedia.org/wiki/Adler-32
|
||||
"""
|
||||
|
||||
|
||||
def adler32(plain_text: str) -> str:
|
||||
"""
|
||||
Function implements adler-32 hash.
|
||||
Itterates and evaluates new value for each character
|
||||
|
||||
>>> adler32('Algorithms')
|
||||
363791387
|
||||
|
||||
>>> adler32('go adler em all')
|
||||
708642122
|
||||
"""
|
||||
MOD_ADLER = 65521
|
||||
a = 1
|
||||
b = 0
|
||||
for plain_chr in plain_text:
|
||||
a = (a + ord(plain_chr)) % MOD_ADLER
|
||||
b = (b + a) % MOD_ADLER
|
||||
return (b << 16) | a
|
Loading…
Reference in New Issue
Block a user