题目
给你两个字符串 s1 和 s2 ,写一个函数来判断 s2 是否包含 s1 的排列。如果是,返回 true ;否则,返回 false 。
换句话说,s1 的排列之一是 s2 的 子串 。
示例
输入:s1 = “ab” s2 = “eidbaooo”
输出:true
解释:s2 包含 s1 的排列之一 (“ba”).
示例 2:
输入:s1= “ab” s2 = “eidboaoo”
输出:false
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/permutation-in-string
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
方法1:滑动窗口
滑动窗口
Python实现
1、将s1存进c1。
2、每次在s2上移动 s1长度的窗口,并判断是否相等。
class Solution:
def checkInclusion(self, s1: str, s2: str) -> bool:
c1=collections.Counter(s1)
n=len(s2)
left=0
right=len(s1)-1
c2=collections.Counter(s2[left:right])
while right<n:
c2[s2[right]] += 1
if c1==c2: return True
c2[s2[left]] -=1
if c2[s2[left]]==0: del c2[s2[left]]
left+=1
right+=1
return False
⭐Java实现1
2021/11/9更新:
框架!!!
class Solution {
public boolean checkInclusion(String s1, String s2) {
Map<Character, Integer> need = new HashMap<>();
Map<Character, Integer> window = new HashMap<>();
for (int i = 0; i < s1.length(); i++){
char c = s1.charAt(i);
need.put(c, need.getOrDefault(c, 0) + 1);
}
int l = 0, r = 0, valid = 0;
while (r < s2.length()){
char c = s2.charAt(r);
r++;
if (need.containsKey(c)){
window.put(c, window.getOrDefault(c, 0) + 1);
if (window.get(c).equals(need.get(c))) valid++;
}
while (r - l == s1.length()){
if (valid == need.size()) return true;
char d = s2.charAt(l);
l++;
if (need.containsKey(d)){
if (need.get(d).equals(window.get(d))) valid--;
window.put(d, window.get(d) - 1);
}
}
}
return false;
}
}
Java实现2
学到了2个map比较的方法! yyds啊
2021/11/9:
我去 这个10月26的代码写的啥子哦,我看半天没看懂,这真的是我本人写的?疑惑(・∀・
class Solution {
public boolean checkInclusion(String s1, String s2) {
Map<Character, Integer> map1 = new HashMap<>(); //对照窗口
Map<Character, Integer> map2 = new HashMap<>(); //s2中的移动窗口
int n=s2.length();
int left=0, right=s1.length()-1;
if (s1.length()>s2.length()) return false;
for (int i=0; i<s1.length(); i++){
if (!map1.containsKey(s1.charAt(i))) map1.put(s1.charAt(i), 1);
else map1.put(s1.charAt(i), map1.get(s1.charAt(i))+1);
}
for (int i=0; i<s1.length(); i++){
if (!map2.containsKey(s2.charAt(i))) map2.put(s2.charAt(i), 1);
else map2.put(s2.charAt(i), map2.get(s2.charAt(i))+1);
}
while (right < n){
if ((map1).equals(map2)) return true;
//右边操作
right++;
if (right==n) break;
if (!map2.containsKey(s2.charAt(right))) map2.put(s2.charAt(right), 1);
else map2.put(s2.charAt(right), map2.get(s2.charAt(right))+1);
//左边操作
map2.put(s2.charAt(left), map2.get(s2.charAt(left))-1);
if (map2.get(s2.charAt(left))==0) map2.remove(s2.charAt(left));
left++;
}
return false;
}
}