# cat blog >> /dev/brain 2> /proc/mind
cat blog >> /dev/brain 2> /proc/mind
# cat mission_03.py import itertools def base4to10(num): result = 0 ln = len(num) - 1 for i in num: result += int(i) * (4 ** ln) ln -= 1 return result def ascii_string(s): for i in s: if ord(i) < 32 or ord(i) > 126: return False return True with open('huffman.code') as f: bd = f.read()[:-1] values = ['0', '1', '00', '01', '10', '11', '000', '001', '010', '011', '100', '101', '110', '111'] for i in itertools.permutations(values, 4): tree = { i[0]: '0', i[1]: '1', i[2]: '2', i[3]: '3', } code = '' result = '' for d in bd: code += d if code in tree: result += tree[code] code = '' try: decv = base4to10(result) hexv = hex(decv)[2:].replace('L', '') ascv = hexv.decode('hex') if ascii_string(ascv) and len(ascv) > 4: print 'tree =', tree print 'result =', result print 'dec =', decv print 'bytes =', hexv print 'ascii =', ascv[::-1] print except: pass # python mission_03.py tree = {'11': '1', '0': '2', '100': '0', '101': '3'} result = 3231202120213111211131203001031030012101202131112031322131303001323130113211313131312111030030013010300120213011212030012101031 dec = 26860288614901905570716094189682157357950360778336264927367113021610209076301 bytes = 3b6262756576304d30646275637a77307b71797777654c30713062716630644d ascii = Md0fqb0q0Lewwyq{0wzcubd0M0veubb; tree = {'11': '1', '0': '3', '100': '0', '101': '2'} result = 2321303130312111311121302001021020013101303121113021233121202001232120112311212121213111020020012010200130312011313020013101021 dec = 21010374883428224108739011194252932925839770786883498221738205492211234141257 bytes = 2e7373657567204920747365726f66206e616d66667548206120736177207449 ascii = It was a Huffman forest I guess.
cat mission_03.py
python mission_03.py
Post a Comment
No comments:
Post a Comment