1371

題目:
https://leetcode.com/problems/find-the-longest-substring-containing-vowels-in-even-counts/description/

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
class Solution {
public:
int findTheLongestSubstring(string s) {
int mp[32]; // uoiea = 00000 -> 11111 => 0~31
for(int i=0; i<32; ++i){
mp[i] = -2; // don't exists
}
mp[0] = -1; // initially 00000

int ans = 0;
int sum = 0;
for(int i=0, m; i<s.length(); ++i){
m = move(s[i]);
if(m != -1) sum ^= 1 << m;
if(mp[sum] != -2) ans = max(ans, i - mp[sum]);
else mp[sum] = i;
}
return ans;
}

int move(char c){
switch(c){
case 'a': return 0;
case 'e': return 1;
case 'i': return 2;
case 'o': return 3;
case 'u': return 4;
default: return -1;
}
}
};