3455. Minimum Length Of String After Operations¶
Difficulty: Medium
LeetCode Problem View on GitHub
3455. Minimum Length of String After Operations
Medium
You are given a string s.
You can perform the following process on s any number of times:
- Choose an index
iin the string such that there is at least one character to the left of indexithat is equal tos[i], and at least one character to the right that is also equal tos[i]. - Delete the closest character to the left of index
ithat is equal tos[i]. - Delete the closest character to the right of index
ithat is equal tos[i].
Return the minimum length of the final string s that you can achieve.
Example 1:
Input: s = "abaacbcbb"
Output: 5
Explanation:
We do the following operations:
- Choose index 2, then remove the characters at indices 0 and 3. The resulting string is
s = "bacbcbb". - Choose index 3, then remove the characters at indices 0 and 5. The resulting string is
s = "acbcb".
Example 2:
Input: s = "aa"
Output: 2
Explanation:
We cannot perform any operations, so we return the length of the original string.
Constraints:
1 <= s.length <= 2 * 105sconsists only of lowercase English letters.
Solution¶
class Solution {
public int minimumLength(String s) {
int n = s.length();
HashMap<Character, Integer> map = new HashMap<>();
for(int i = 0; i < n; i++) map.put(s.charAt(i), map.getOrDefault(s.charAt(i) , 0) + 1);
int total = n;
for(Map.Entry<Character, Integer> curr : map.entrySet()) {
char key = curr.getKey();
int val = curr.getValue();
int count = 0;
if(val >= 3) {
while(val >= 3) {
val -= 2;
count++;
}
}
total -= count * 2;
}
return total;
}
}
Complexity Analysis¶
- Time Complexity:
O(?) - Space Complexity:
O(?)
Approach¶
Detailed explanation of the approach will be added here