
def priority_queue_assignment(threshold, groups, queue):
    """
    threshold: priorities above threshold merge groups
    groups: Dict of { index:group }
    queue: Sorted list of items [(priority_ij, i, j)]
    """
    while len(queue) > 0:
        sim, i, j = queue.pop()
        if sim > threshold:
        	left_group = groups[j]                                              
  13            for k,v in groups.items():                                          
  14                if v == left_group:                                             
  15                   groups[k] = groups[i] 
        else:
            break
    
    return groups


