Problem
You are given a string s
and two integers x
and y
. You can perform two types of operations any number of times.
Remove substring "ab"
and gain x
points.
For example, when removing
"ab"
from"cabxbae"
it becomes"cxbae"
.Remove substring
"ba"
and gainy
points.For example, when removing
"ba"
from"cabxbae"
it becomes"cabxe"
.
Return the maximum points you can gain after applying the above operations on s
.
Example 1:
Input: s = "cdbcbbaaabab", x = 4, y = 5
Output: 19
Explanation:
- Remove the "ba" underlined in "cdbcbbaaabab". Now, s = "cdbcbbaaab" and 5 points are added to the score.
- Remove the "ab" underlined in "cdbcbbaaab". Now, s = "cdbcbbaa" and 4 points are added to the score.
- Remove the "ba" underlined in "cdbcbbaa". Now, s = "cdbcba" and 5 points are added to the score.
- Remove the "ba" underlined in "cdbcba". Now, s = "cdbc" and 5 points are added to the score.
Total score = 5 + 4 + 5 + 5 = 19.
Example 2:
Input: s = "aabbaaxybbaabb", x = 5, y = 4
Output: 20
Constraints:
1 <= s.length <= 10^5
1 <= x, y <= 10^4
s
consists of lowercase English letters.
Solution (Java)
class Solution {
public int maximumGain(String s, int x, int y) {
char[] v = s.toCharArray();
if (x > y) {
return helper(v, 'a', 'b', x) + helper(v, 'b', 'a', y);
} else {
return helper(v, 'b', 'a', y) + helper(v, 'a', 'b', x);
}
}
private int helper(char[] v, char c1, char c2, int score) {
int left = -1;
int right = 0;
int res = 0;
while (right < v.length) {
if (v[right] != c2) {
left = right;
} else {
while (left >= 0) {
char cl = v[left];
if (cl == '#') {
left--;
} else if (cl == c1) {
res += score;
v[left] = '#';
v[right] = '#';
left--;
break;
} else {
break;
}
}
}
right++;
}
return res;
}
}
Explain:
nope.
Complexity:
- Time complexity : O(n).
- Space complexity : O(n).