#!/usr/bin/python
# -*- coding: UTF-8 -*-

import numpy as np
from DONtwo import DONtwo1


def FNDSF1(pa):
    N = len(pa)
    C = len(pa[0])
    FL = []
    F = np.zeros((N, N))
    Fpa = np.zeros((N, C + 2))
    Fpa[:, 0: 2] = pa
    S = np.zeros((N, N))
    for p in range(0, N):
        P = pa[p, :]
        Sp = []
        SS = []
        for q in range(0, N):
            Q = pa[q, :]
            if DONtwo1(P, Q) == 1:
                Sp.append(q)
            elif DONtwo1(Q, P) == 1:
                Fpa[p, C] = Fpa[p, C] + 1
            mm = np.array(Sp)
            S[p, 0:len(Sp)] = np.array(Sp)
            SS.append(Sp)
        if Fpa[p, C] == 0:
            Fpa[p, C + 1] = 1
    i = 1
    isign = [k for k, x in enumerate(Fpa[:, C + 1]) if x == i]
    while len(isign) != 0:
        for p in range(0, len(isign)):
            m=isign[p]
            zzz = S[isign[p], :]
            aaa = [k for k, x in enumerate(zzz) if x == 0]
            for q in range(0, len(zzz)):
                if zzz[q] == 0 and q != 0:
                    break
                else:
                    m=int(zzz[q])
                    Fpa[m, C] = Fpa[m, C] - 1
                    if Fpa[m, C] == 0 or Fpa[m, C] == -1:
                        Fpa[m, C + 1] = i + 1
        i = i + 1
        isign = []
        isign = [k for k, x in enumerate(Fpa[:, C + 1]) if x == i]
    FL = Fpa[:, C + 1]-1
    return FL
