-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
Copy pathcount-of-substrings-containing-every-vowel-and-k-consonants-i.cpp
88 lines (81 loc) · 2.53 KB
/
count-of-substrings-containing-every-vowel-and-k-consonants-i.cpp
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
76
77
78
79
80
81
82
83
84
85
86
87
88
// Time: O(n)
// Space: O(1)
// two pointers, sliding window, freq table
class Solution {
public:
int countOfSubstrings(string word, int k) {
static const unordered_set<char> VOWELS = {'a', 'e', 'i', 'o', 'u'};
vector<int> cnt1(26), cnt2(26);
int curr1 = 0, curr2 = 0;
const auto& update = [&](int i, int d) {
if (!VOWELS.count(word[i])) {
curr2 += d;
return;
}
const auto x = word[i] - 'a';
if (cnt1[x] == 0) {
++curr1;
}
cnt1[x] += d;
if (cnt1[x] == 0) {
--curr1;
}
};
int64_t result = 0;
for (int right = 0, left = 0, mid = 0; right < size(word); ++right) {
update(right, +1);
while (curr2 > k) {
update(left, -1);
if (left < mid) {
--cnt2[word[left] - 'a'];
}
mid = max(mid, ++left);
}
if (!(curr1 == size(VOWELS) && curr2 == k)) {
continue;
}
for (; VOWELS.count(word[mid]) && cnt1[word[mid] - 'a'] - (cnt2[word[mid] - 'a'] + 1) >= 1; ++mid) {
++cnt2[word[mid] - 'a'];
}
result += mid - left + 1;
}
return result;
}
};
// Time: O(n)
// Space: O(1)
// two pointers, sliding window, freq table
class Solution2 {
public:
int countOfSubstrings(string word, int k) {
static const unordered_set<char> VOWELS = {'a', 'e', 'i', 'o', 'u'};
const auto& count = [&](int k) {
vector<int> cnt(26);
int curr1 = 0, curr2 = 0;
const auto& update = [&](int i, int d) {
if (!VOWELS.count(word[i])) {
curr2 += d;
return;
}
const auto x = word[i] - 'a';
if (cnt[x] == 0) {
++curr1;
}
cnt[x] += d;
if (cnt[x] == 0) {
--curr1;
}
};
int64_t result = 0;
for (int right = 0, left = 0; right < size(word); ++right) {
update(right, +1);
for (; curr1 >= size(VOWELS) && curr2 >= k; ++left) {
result += size(word) - right;
update(left, -1);
}
}
return result;
};
return count(k) - count(k + 1);
}
};