1717. Maximum Score From Removing Substrings

Difficulty:
Related Topics:
Similar Questions:

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.

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:

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: