-
Notifications
You must be signed in to change notification settings - Fork 277
/
Copy pathCountVowelsPermutation.java
35 lines (32 loc) · 1.12 KB
/
CountVowelsPermutation.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
class Solution {
private Map<String,Long> map = new HashMap<>();
private int MOD = 1000000007;
public int countVowelPermutation(int n) {
long total = 0;
char[] charSet = new char[]{'a','e','i','o','u'};
for(char c : charSet) {
total = (total + helper(n-1,c)) % MOD;
}
return (int)total;
}
public long helper(int remaingChar, char prevChar) {
if(remaingChar == 0) return 1;
String key = "" + remaingChar + prevChar;
if(map.containsKey(key)) return map.get(key);
long total = 0;
switch(prevChar) {
case 'a': total = (helper(remaingChar - 1,'e')) % MOD;
break;
case 'e': total = (helper(remaingChar - 1,'a') + helper(remaingChar - 1, 'i')) % MOD;
break;
case 'i': total = (helper(remaingChar - 1,'a') + helper(remaingChar - 1, 'e') + helper(remaingChar - 1, 'o') + helper(remaingChar - 1, 'u')) % MOD;
break;
case 'o': total = (helper(remaingChar - 1,'i') + helper(remaingChar - 1,'u')) % MOD;
break;
case 'u': total = (helper(remaingChar - 1,'a')) % MOD;
break;
}
map.put(key , total);
return total;
}
}