from typing import List
import numpy as np
from scipy.optimize import linear_sum_assignment

def _distance(x1: float, x2: float) -> float:
    return min(1, abs((x1 - x2) / (x1 + 1e-15)))


def _compute_cost_matrix(a1: List[float], a2: List[float]) -> np.ndarray:
    cost_matrix = np.zeros((len(a1), len(a2)))
    for i, v1 in enumerate(a1):
        for j, v2 in enumerate(a2):
            cost_matrix[i, j] = _distance(v1, v2)
    return cost_matrix

def _remove_strings(flat_values: List) -> List[float]:
    new_lst = []
    for elt in flat_values:
        elt = str(elt).replace("%", "")
        try:
            new_lst.append(float(elt))
        except Exception:
            continue
    return new_lst
    
def _compute_score(lst1: List[float], lst2: List[float]) -> float:
    cost_matrix = _compute_cost_matrix(lst1, lst2)
    row_ind, col_ind = linear_sum_assignment(cost_matrix)
    cost = cost_matrix[row_ind, col_ind].sum()
    score = 1 - cost / max(len(lst1), len(lst2))
    return float(score)