forked from fishercoder1534/Leetcode
-
Notifications
You must be signed in to change notification settings - Fork 8
/
_567.java
75 lines (63 loc) · 2.39 KB
/
_567.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
package com.fishercoder.solutions;
/**
* Given two strings s1 and s2, write a function to return true if s2 contains the permutation of s1.
* In other words, one of the first string's permutations is the substring of the second string.
Example 1:
Input:s1 = "ab" s2 = "eidbaooo"
Output:True
Explanation: s2 contains one permutation of s1 ("ba").
Example 2:
Input:s1= "ab" s2 = "eidboaoo"
Output: False
Note:
The input strings only contain lower case letters.
The length of both given strings is in range [1, 10,000].
*/
public class _567 {
//credit: sliding window: https://discuss.leetcode.com/topic/87845/java-solution-sliding-window
/**1. How do we know string p is a permutation of string s? Easy, each character in p is in s too.
* So we can abstract all permutation strings of s to a map (Character -> Count). i.e. abba -> {a:2, b:2}.
* Since there are only 26 lower case letters in this problem, we can just use an array to represent the map.
2. How do we know string s2 contains a permutation of s1?
We just need to create a sliding window with length of s1,
move from beginning to the end of s2.
When a character moves in from right of the window,
we subtract 1 to that character count from the map.
When a character moves out from left of the window,
we add 1 to that character count. So once we see all zeros in the map,
meaning equal numbers of every characters between s1 and the substring in the sliding window, we know the answer is true.
*/
public boolean checkInclusion(String s1, String s2) {
int len1 = s1.length();
int len2 = s2.length();
if (len1 > len2) {
return false;
}
int[] count = new int[26];
for (int i = 0; i < len1; i++) {
count[s1.charAt(i) - 'a']++;
}
for (int i = 0; i < len1; i++) {
count[s2.charAt(i) - 'a']--;
}
if (allZeroes(count)) {
return true;
}
for (int i = len1; i < len2; i++) {
count[s2.charAt(i) - 'a']--;
count[s2.charAt(i - len1) - 'a']++;
if (allZeroes(count)) {
return true;
}
}
return false;
}
private boolean allZeroes(int[] count) {
for (int i : count) {
if (i != 0) {
return false;
}
}
return true;
}
}