import numpy as np

def levenshtein(seq1, seq2):
    size_x = len(seq1) + 1
    size_y = len(seq2) + 1
    matrix = np.zeros ((size_x, size_y))
    for x in range(size_x):
        matrix [x, 0] = x
    for y in range(size_y):
        matrix [0, y] = y
            
    for x in range(1, size_x):
        for y in range(1, size_y):
            if seq1[x-1] == seq2[y-1]:
                matrix [x,y] = min(
                    matrix[x-1, y] + 1,
                    matrix[x-1, y-1],
                    matrix[x, y-1] + 1
                )
            else:
                matrix [x,y] = min(
                    matrix[x-1,y] + 1,
                    matrix[x-1,y-1] + 1,
                    matrix[x,y-1] + 1
                )
    return (matrix[size_x - 1, size_y - 1])


lst = list(open("f").readlines())
lst = [y.strip() for x,y in zip(lst,lst[1:]) if 'Classif' in x]

for i in range(0,len(lst),3):
    print("A:", lst[i])
    #print("B:", lst[i+1], '|', lst[i+2])
    #print("D:", levenshtein(lst[i], lst[i+1]+lst[i+2])/len(lst[i]))
    print("B:", lst[i+1])
    print("D:", levenshtein(lst[i][:len(lst[i])//2], lst[i+1])/(len(lst[i])/2))
