Back to all solutions
             
  #1750 - Minimum Length of String After Deleting Similar Ends
Problem Description
Given a string s consisting only of characters 'a', 'b', and 'c'. You are asked to apply the following algorithm on the string any number of times:
- Pick a non-empty prefix from the string s where all the characters in the prefix are equal.
- Pick a non-empty suffix from the string s where all the characters in this suffix are equal.
- The prefix and the suffix should not intersect at any index.
- The characters from the prefix and suffix must be the same.
- Delete both the prefix and the suffix.
Return the minimum length of s after performing the above operation any number of times (possibly zero times).
Solution
/**
 * @param {string} s
 * @return {number}
 */
var minimumLength = function(s) {
  let left = 0;
  let right = s.length - 1;
  while (left < right && s[left] === s[right]) {
    const char = s[left];
    while (left <= right && s[left] === char) left++;
    while (left <= right && s[right] === char) right--;
  }
  return Math.max(0, right - left + 1);
};