2025-01-13 Daily Challenge
Today I have done leetcode's January LeetCoding Challenge with cpp.
January LeetCoding Challenge 13
Description
Minimum Length of String After Operations
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) {
vector<int> count(26);
for(auto c : s) {
c -= 'a';
count[c] += 1;
if(count[c] > 2) count[c] -= 2;
}
return accumulate(count.begin(), count.end(), 0);
}
};
// Accepted
// 702/702 cases passed (32 ms)
// Your runtime beats 58.47 % of cpp submissions
// Your memory usage beats 86.69 % of cpp submissions (32 MB)