Problem
Given a string s
, return true
if the s
can be palindrome after deleting at most one character from it.
Examples
Example 1:
Input:
s = "aba"
Output:
true
Example 2:
Input:
s = "abca"
Output:
true
Explanation: You could delete the character 'c'.
Example 3:
Input:
s = "abc"
Output:
false
Solution
Method 1 - Using Two Pointers
We can use the old approach like in Valid Palindrome. But with some modification.
For eg. take aaaz
; Now when we compare left
and right
values, i.e. a
and z
, we can see they are different. But it is fine, as 1 char can be deleted. So, should it be z
OR a
. So, when we remove z
, we get it is as palindrome. So, we have to try out both aaa
and aaz
to see if they are palindrome.
Code
Java
public boolean validPalindrome(String s) {
int i = 0;
int j = s.length() - 1;
while (i < j) {
if (s.charAt(i) != s.charAt(j)) {
return isPalindrome(s, i + 1, j) || isPalindrome(s, i, j - 1);
}
i++;
j--;
}
return true;
}
private boolean isPalindrome(String s, int i, int j) {
while (i < j) {
if (s.charAt(i++) != s.charAt(j--)) {
return false;
}
}
return true;
}
Complexity
- ⏰ Time complexity:
O(n)
- 🧺 Space complexity:
O(1)