How can I create a tree for Huffman encoding and decoding?

前端 未结 5 1910
轮回少年
轮回少年 2021-02-05 21:04

For my assignment, I am to do a encode and decode for huffman trees. I have a problem creating my tree, and I am stuck.

Don\'t mind the print statements - they are just

5条回答
  •  一向
    一向 (楼主)
    2021-02-05 21:15

    I was working out this problem today, to try and match results in above response. For most part, this solution works well but only thing i find non-intuitive is to add [0] and [1] in printing the non-node (leaf). But this answers miracles question - you can essentially print it using any traversal mechanism

    import queue
    
    class HuffmanNode(object):
        def __init__(self,left=None,right=None,root=None):
            self.left = left
            self.right = right
            self.root = root
        def children(self):
            return (self.left,self.right)
        def preorder(self,path=None):
            if path is None:
                path = []
            if self.left is not None:
                if isinstance(self.left[1], HuffmanNode):
                    self.left[1].preorder(path+[0])
                else:
                    print(self.left,path+[0])
            if self.right is not None:
                if isinstance(self.right[1], HuffmanNode):
                    self.right[1].preorder(path+[1])
                else:
                    print(self.right,path+[1])
    
    freq = [
        (8.167, 'a'), (1.492, 'b'), (2.782, 'c'), (4.253, 'd'),
        (12.702, 'e'),(2.228, 'f'), (2.015, 'g'), (6.094, 'h'),
        (6.966, 'i'), (0.153, 'j'), (0.747, 'k'), (4.025, 'l'),
        (2.406, 'm'), (6.749, 'n'), (7.507, 'o'), (1.929, 'p'), 
        (0.095, 'q'), (5.987, 'r'), (6.327, 's'), (9.056, 't'), 
        (2.758, 'u'), (1.037, 'v'), (2.365, 'w'), (0.150, 'x'),
        (1.974, 'y'), (0.074, 'z') ]
    
    def encode(frequencies):
        p = queue.PriorityQueue()
        for item in frequencies:
            p.put(item)
    
        #invariant that order is ascending in the priority queue
        #p.size() gives list of elements
        while p.qsize() > 1:
            left,right = p.get(),p.get()
            node = HuffmanNode(left,right)
            p.put((left[0]+right[0],node))
        return p.get()
    
    node = encode(freq)
    print(node[1].preorder())
    

提交回复
热议问题