题目
给定一个非空字符串 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;
};