680.验证回文字符串II

题目

给定一个非空字符串 s,最多删除一个字符。判断是否能成为回文字符串。

示例 1:
输入: "aba"
输出: True

示例 2:
输入: "abca"
输出: True
解释: 你可以删除c字符。

注意:

  • 字符串只包含从 a-z 的小写字母。字符串的最大长度是50000。

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/valid-palindrome-ii 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

JS实现

/**
 * @param {string} s
 * @return {boolean}
 */
var validPalindrome = function (s) {
  // 双指针,一个指向字符串开头,一个指向字符串末尾
  let i = 0,
    j = s.length - 1;

  // 判断是否是回文串
  const isPalindrome = (low, high) => {
    while (low < high) {
      if (s.charAt(low) != s.charat(high)) {
        return false;
      }
      low++;
      high--;
    }
    return true;
  };

  while (i < j) {
    // 字符串开头与末尾不相等
    if (s.charAt(i) != s.charAt(j)) {
      // 开头移除一位 or 末尾移除一位
      return isPalindrome(i + 1, j) || isPalindrome(i, j - 1);
    }
    i++;
    j--;
  }
  return true;
};