A phrase is a palindrome if, after converting all uppercase letters into lowercase letters and removing all non-alphanumeric characters, it reads the same forward and backward. Alphanumeric characters include letters and numbers.
Given a string s
, return true
if it is a palindrome, or false
otherwise.
Example 1:
Input: s = "A man, a plan, a canal: Panama"
Output: true
Explanation: "amanaplanacanalpanama"
is a palindrome.
Solution 1
- Time:
- Space:
- Create a “cleaned” version of the string with only alphanumeric characters and all in lower case
- Compare the cleaned version of the string against its reverse (Slice Notation)
Solution
Here’s another solution with:
- Constant extra memory (we don’t have to create a
cleaned
string like above). This is basically a 2 pointers solution. - No use of
isalpha()
orisdigit()
. - Still time complexity.