Skip to content

Latest commit

 

History

History
41 lines (27 loc) · 1.21 KB

File metadata and controls

41 lines (27 loc) · 1.21 KB

Key information:

  • Lossless compression based on frequency => Huffman Encoding
  • Node data is pickled

In info.txt there is an encoded message and a url to node_data.txt. We need to unpickle node data to rebuild huffman tree, address from the root to decode the data. To unpickle the Node object, we need to define a fake Node class to bypass the unpickle error AttributeError: Can't get attribute 'Node' on <module 'main'....

class Node():

    def __init__(self):
        print('fake node to bypass attribute-not-found error in pickle.load')

In a Node object, left and right is the left and right child, respectively, data field on leaves is the value we need, so decoded as following.

def decode(node, data):
    flag = ''
    cur = node

    for i in range(len(data)):
        if not cur.left and not cur.right:
            flag += cur.data
            cur = node

        if data[i] == '0':
            cur = cur.left
        else:
            cur = cur.right

    if not cur.left and not cur.right:
        flag += cur.data

    return flag

The decoded message is Tony_Stark:_I_Build_Neat_Stuff,_Got_A_Great_Girl,_Occasionally_Save_The_World._So_flag{Why_Can’t_I_Sleep?}.