█████████ ████ ███░░░░░███ ░░███ ███ ░░░ ██████ ███████ ██████ ██████ ░███ ███░░███ ███░░███ ███░░███ ███░░███ ░███ ░███ ░███░███ ░███ ░███████ ░███ ░███ ░░███ ███░███ ░███░███ ░███ ░███░░░ ░███ ░███ ░░█████████ ░░██████ ░░████████░░██████ ░░██████ ░░░░░░░░░ ░░░░░░ ░░░░░░░░ ░░░░░░ ░░░░░░

Envío 7185

Problema 0x43 - Encontrar el borde más largo de una string

  • Autor: Jorgito
  • Fecha: 2023-11-06 16:03:48 UTC (Hace alrededor de 1 año)
Caso # Resultado Tiempo Memoria
#1
Incorrecto
0.031 s 15 KBi
#2
Incorrecto
0.027 s 15 KBi
#3
Incorrecto
0.033 s 15 KBi
#4
Incorrecto
0.021 s 15 KBi
#5
Correcto
0.022 s 15 KBi
#6
Correcto
0.021 s 15 KBi
#7
Tiempo límite excedido
1.599 s 23 KBi
#8
Tiempo límite excedido
1.592 s 23 KBi
#9
Tiempo límite excedido
1.571 s 23 KBi
#10
Tiempo límite excedido
1.585 s 23 KBi
#11
Tiempo límite excedido
1.593 s 23 KBi
#12
Tiempo límite excedido
1.592 s 23 KBi
#13
Tiempo límite excedido
1.599 s 23 KBi
#14
Tiempo límite excedido
1.56 s 23 KBi
#15
Tiempo límite excedido
1.599 s 23 KBi
#16
Tiempo límite excedido
1.588 s 23 KBi
#17
Tiempo límite excedido
1.583 s 24 KBi
#18
Tiempo límite excedido
1.597 s 26 KBi
#19
Tiempo límite excedido
1.598 s 24 KBi
#20
Tiempo límite excedido
1.596 s 26 KBi
#21
Tiempo límite excedido
1.597 s 26 KBi
#22
Tiempo límite excedido
1.598 s 23 KBi
Puntos totales: 10 / 100

Código

class SuffixArray:
    def __init__(self, T):
        self.T = T + '$'
        self.n = len(self.T)
        self.MAX_N = 201000
        self.c = [0] * self.MAX_N
        self.RA = [0] * self.MAX_N
        self.tempRA = [0] * self.MAX_N
        self.SA = [0] * self.MAX_N
        self.tempSA = [0] * self.MAX_N
        self.Phi = [0] * self.MAX_N
        self.PLCP = [0] * self.MAX_N
        self.LCP = [0] * self.MAX_N

    def counting_sort(self, k):
        maxi = max(300, self.n)
        count = [0] * maxi
        tempSA = [0] * self.n

        for i in range(self.n):
            count[self.RA[self.SA[i] + k] if self.SA[i] + k < self.n else 0] += 1
        for i in range(1, maxi):
            count[i] += count[i - 1]
        for i in range(self.n - 1, -1, -1):
            tempSA[count[self.RA[self.SA[i] + k] if self.SA[i] + k < self.n else 0] - 1] = self.SA[i]
            count[self.RA[self.SA[i] + k] if self.SA[i] + k < self.n else 0] -= 1
        for i in range(self.n):
            self.SA[i] = tempSA[i]

    def construct_SA(self):
        for i in range(self.n):
            self.RA[i] = ord(self.T[i])
            self.SA[i] = i
        k = 1
        while k < self.n:
            self.counting_sort(k)
            self.counting_sort(0)
            tempRA = [0] * self.n
            r = 0
            tempRA[self.SA[0]] = r
            for i in range(1, self.n):
                tempRA[self.SA[i]] = r if self.RA[self.SA[i]] == self.RA[self.SA[i - 1]] and \
                                           self.RA[self.SA[i] + k] == self.RA[self.SA[i - 1] + k] else r + 1
                r = tempRA[self.SA[i]]
            self.RA = tempRA[:]
            k <<= 1

    def compute_LCP(self):
        phi = [-1] * self.n
        L = 0
        for i in range(1, self.n):
            phi[self.SA[i]] = self.SA[i - 1]
            while i + L < self.n and phi[i] + L < self.n and self.T[i + L] == self.T[phi[i] + L]:
                L += 1
            self.PLCP[i] = L
            L = max(L - 1, 0)
        for i in range(1, self.n):
            self.LCP[i] = self.PLCP[self.SA[i]]

    def get_border(self):
        res = -1
        for i in range(self.n):
            if self.SA[i] == 0:
                res = i
                break
        mn = self.LCP[res]
        i = res
        while i > 0 and self.n - 1 - self.SA[i - 1] == mn:
            i -= 1
            mn = min(mn, self.LCP[i])
        if i <= 0 or self.n - 1 - self.SA[i - 1] != mn:
            return -1
        else:
            return mn

    def run(self):
        self.construct_SA()
        self.compute_LCP()
        res = self.get_border()
        if res == -1:
            print(0)
        else:
            print(res)


if __name__ == "__main__":
    T = input()
    suffix_array = SuffixArray(T)
    suffix_array.run()