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;
}
}