function isPerfect = check_perfect_matching(row, col, D, N_deg1, N_deg2, F_deg1, F_deg2)

    n = length(row);
    [value, idx] = max(D);

    for j = 1:(row(idx) - 1)

        Dij = dwass_discrete2(N_deg1{row(idx)}, N_deg2{j}, F_deg1{row(idx)}, F_deg2{j});

        if Dij < value
            isPerfect = 0;
            return
        end
        
    end

    for j = (row(idx) + 1):n

        Dij = dwass_discrete2(N_deg1{row(idx)}, N_deg2{j}, F_deg1{row(idx)}, F_deg2{j});

        if Dij < value
            isPerfect = 0;
            return
        end
        
    end

    for i = 1:(col(idx) - 1)

        Dij = dwass_discrete2(N_deg1{i}, N_deg2{col(idx)}, F_deg1{i}, F_deg2{col(idx)});

        if Dij < value
            isPerfect = 0;
            return
        end
        
    end

    for i = (col(idx) + 1):n

        Dij = dwass_discrete2(N_deg1{i}, N_deg2{col(idx)}, F_deg1{i}, F_deg2{col(idx)});

        if Dij < value
            isPerfect = 0;
            return
        end
        
    end
    

    isPerfect = 1;

end