bi.1/script.py

73 lines
1.9 KiB
Python
Raw Permalink Normal View History

2017-12-13 19:34:45 +01:00
#-*-encoding:utf-8-*-
2017-12-11 17:00:59 +01:00
2017-12-13 19:34:45 +01:00
from hashlib import md5
from binascii import hexlify
2017-12-13 22:59:01 +01:00
import datetime
2017-12-11 17:00:59 +01:00
2017-12-13 19:34:45 +01:00
renmich_1 = 'renmich1123376350383621786626'.encode();
renmich_2 = 'renmich3700873222361195459231'.encode();
2017-12-13 22:59:01 +01:00
my_input = 'rabanbar'.encode();
2017-12-13 19:34:45 +01:00
def rmhash(input,n=1):
tmp = input;
for i in range(n):
x = md5();
x.update(tmp);
y = md5();
y.update(x.digest())
2017-12-13 22:59:01 +01:00
tmp = y.digest()[:7]
2017-12-13 19:34:45 +01:00
return tmp;
def to_string(b):
return hexlify(b).decode();
2017-12-11 17:00:59 +01:00
def find_colision(input):
2017-12-13 22:59:01 +01:00
begin_time = datetime.datetime.now()
2017-12-11 17:00:59 +01:00
tortoise=input;
hare=input;
i=0;
2017-12-13 19:34:45 +01:00
dlugosc_cyklu = 1;
2017-12-11 17:00:59 +01:00
pierwsze_wystapienie_cyklu = 0;
while i==0 or tortoise!=hare:
i+=1;
tortoise=rmhash(tortoise);
hare=rmhash(hare);
hare=rmhash(hare);
2017-12-13 19:34:45 +01:00
print("{}: zolw={} zajac={} ".format(i,to_string(tortoise), to_string(hare)))
# Zolw na poczatek
tortoise = input;
while tortoise != hare:
previous_tortoise = tortoise;
tortoise = rmhash(tortoise);
hare = rmhash(hare)
pierwsze_wystapienie_cyklu += 1;
2017-12-11 17:00:59 +01:00
#Przesuwam zajaca o jedno pole do przodu
2017-12-13 19:34:45 +01:00
hare=rmhash(tortoise);
2017-12-11 17:00:59 +01:00
while tortoise!=hare:
previous_hare = hare;
hare=rmhash(hare);
dlugosc_cyklu+=1;
2017-12-13 19:34:45 +01:00
print("Zajac jest na polu {} a byl na {}".format(to_string(hare),to_string(previous_hare)))
print("Zolw jest na polu {} a byl na {}".format(to_string(tortoise),to_string(previous_tortoise)))
print("Dlugosc cyklu: {}; Pierwsze wystapienie cyklu {}".format(dlugosc_cyklu,pierwsze_wystapienie_cyklu))
collision_a = rmhash(input,pierwsze_wystapienie_cyklu-1);
collision_b = rmhash(input, pierwsze_wystapienie_cyklu + dlugosc_cyklu-1);
print("Hash ciagow: {}, {} to {}".format(to_string(collision_a),to_string(collision_b),to_string(rmhash(collision_a))))
2017-12-13 22:59:01 +01:00
print("Poczatek: {} Koniec: {}".format(begin_time,datetime.datetime.now()))
2017-12-13 19:34:45 +01:00
return(collision_a,collision_b);