84 lines
2.3 KiB
Java
84 lines
2.3 KiB
Java
|
//给定两个字符串 s 和 p,找到 s 中所有 p 的 异位词 的子串,返回这些子串的起始索引。不考虑答案输出的顺序。
|
|||
|
//
|
|||
|
// 异位词 指字母相同,但排列不同的字符串。
|
|||
|
//
|
|||
|
//
|
|||
|
//
|
|||
|
// 示例 1:
|
|||
|
//
|
|||
|
//
|
|||
|
//输入: s = "cbaebabacd", p = "abc"
|
|||
|
//输出: [0,6]
|
|||
|
//解释:
|
|||
|
//起始索引等于 0 的子串是 "cba", 它是 "abc" 的异位词。
|
|||
|
//起始索引等于 6 的子串是 "bac", 它是 "abc" 的异位词。
|
|||
|
//
|
|||
|
//
|
|||
|
// 示例 2:
|
|||
|
//
|
|||
|
//
|
|||
|
//输入: s = "abab", p = "ab"
|
|||
|
//输出: [0,1,2]
|
|||
|
//解释:
|
|||
|
//起始索引等于 0 的子串是 "ab", 它是 "ab" 的异位词。
|
|||
|
//起始索引等于 1 的子串是 "ba", 它是 "ab" 的异位词。
|
|||
|
//起始索引等于 2 的子串是 "ab", 它是 "ab" 的异位词。
|
|||
|
//
|
|||
|
//
|
|||
|
//
|
|||
|
//
|
|||
|
// 提示:
|
|||
|
//
|
|||
|
//
|
|||
|
// 1 <= s.length, p.length <= 3 * 104
|
|||
|
// s 和 p 仅包含小写字母
|
|||
|
//
|
|||
|
// Related Topics 哈希表 字符串 滑动窗口
|
|||
|
// 👍 586 👎 0
|
|||
|
|
|||
|
package leetcode.editor.cn;
|
|||
|
|
|||
|
import java.util.ArrayList;
|
|||
|
import java.util.Arrays;
|
|||
|
import java.util.List;
|
|||
|
|
|||
|
//438:找到字符串中所有字母异位词
|
|||
|
class FindAllAnagramsInAString {
|
|||
|
public static void main(String[] args) {
|
|||
|
//测试代码
|
|||
|
Solution solution = new FindAllAnagramsInAString().new Solution();
|
|||
|
System.out.println(solution.findAnagrams("cbaebabacd", "abc"));
|
|||
|
}
|
|||
|
|
|||
|
//力扣代码
|
|||
|
//leetcode submit region begin(Prohibit modification and deletion)
|
|||
|
class Solution {
|
|||
|
public List<Integer> findAnagrams(String s, String p) {
|
|||
|
if(p.length()>s.length()){
|
|||
|
return new ArrayList<>();
|
|||
|
}
|
|||
|
int[] pchs = new int[26];
|
|||
|
for (char ch : p.toCharArray()) {
|
|||
|
pchs[ch - 'a']++;
|
|||
|
}
|
|||
|
char[] schs = s.toCharArray();
|
|||
|
int start = 0;
|
|||
|
int[] chs = new int[26];
|
|||
|
List<Integer> list = new ArrayList<>();
|
|||
|
for (int i = 0; i < p.length() - 1; i++) {
|
|||
|
chs[schs[i] - 'a']++;
|
|||
|
}
|
|||
|
for (int i = p.length() - 1; i < schs.length; i++) {
|
|||
|
chs[schs[i] - 'a']++;
|
|||
|
if (Arrays.equals(pchs, chs)) {
|
|||
|
list.add(start);
|
|||
|
}
|
|||
|
chs[schs[start] - 'a']--;
|
|||
|
start++;
|
|||
|
}
|
|||
|
return list;
|
|||
|
}
|
|||
|
}
|
|||
|
//leetcode submit region end(Prohibit modification and deletion)
|
|||
|
|
|||
|
}
|