Java aplicación LeetCode 438 ectópico encontrar todas las letras de la palabra cadena

438. ectópico encontrar todas las letras de la palabra cadena

Dada una cadena s y un índice de cadena no vacía a partir de p, encuentra toda s es una subcadena de ectópico palabra letra p, y retorna la subcadena.

Cadena contiene solamente letras minúsculas, y la longitud de cadena de caracteres P y S no es más de 20.100.

Descripción:

Ectópicos palabra letras se refieren a las mismas letras, pero dispuestos en diferentes cadenas.
El orden de las respuestas que no fueron considerados.
Ejemplo 1:

Entrada:
S: "cbaebabacd" P: "ABC"

Salida:
[0, 6]

Explicación:
Índice inicial de 0 es igual a la subcadena "CBA", que es ectópicos palabras de la letra "ABC".
6 subcadena índice de partida es igual a "bac", que es palabras de la letra ectópicos "ABC".
Ejemplo 2:

Entrada:
S: "ABAB" P: "AB &"

Salida:
[0, 1, 2]

Explicación:
Índice inicial de 0 es igual a la subcadena "ab", que es ectópicos palabras de la letra "AB".
Subcadena que empieza índice 1 es igual a "BA", que es palabras de la letra ectópicos "AB".
2 subcadena índice de partida es igual a "ab", que es palabras de la letra ectópicos "AB".

class Solution {
 
    public List<Integer> findAnagrams(String s, String p) {
        List<Integer> res = new ArrayList<>();
        if (p.length() > s.length())
            return res;

        int[] pLetterCounts = new int[26];
        int[] sLetterCounts = new int[26];
        for (int i = 0; i < p.length(); ++i) {
            pLetterCounts[p.charAt(i) - 'a']++;
            sLetterCounts[s.charAt(i) - 'a']++;
        }

        for (int endIdx = p.length() - 1; endIdx < s.length(); ++endIdx) {
            int startIdx = endIdx - p.length() + 1;
            boolean isAnagrams = true;
            for (int i = 0; i < 26; ++i) {
                if (sLetterCounts[i] != pLetterCounts[i]) {
                    isAnagrams = false;
                    break;
                }
            }

            if (isAnagrams)
                res.add(startIdx);

            if (endIdx != s.length() - 1){
                sLetterCounts[s.charAt(startIdx) - 'a']--;
                sLetterCounts[s.charAt(endIdx + 1) - 'a']++;
            }

        }

        return res;
    }
}
Liberadas 1545 artículos originales · ganado elogios 20000 + · vistas 2,19 millones +

Supongo que te gusta

Origin blog.csdn.net/a1439775520/article/details/104910582
Recomendado
Clasificación