[LeetCode] Top Interview 150 Problems Solving # 125 Valid Palindrome

Understanding the Problem
It is a palindrome problem with some extra steps to solve it. Some sentences are included in the test cases like s = "A man, a plan, a canal: Panama"
. It is only to be left with lower case alpha numerical characters, which will form as ”amanaplanacanalpanama”
and this is a palindrome.
An empty string s = ““
is also considered as a palindrome.
Approach
It was nothing much to think personally, so I went with filtering the alpha numeric characters only. I wanted to go loop with for
and check from both sides of the string.
Solution
class Solution:
def isPalindrome(self, s: str) -> bool:
new_s = ""
for c in s:
# if (c.lower() >= "a" and c.lower() <= "z") or (c.lower() >= "0" and c.lower() <= "9"):
# new_s += c.lower()
if c.lower().isalnum():
new_s += c.lower()
if new_s == "":
return True
for i in range(len(new_s)//2):
if new_s[i] != new_s[-(i+1)]:
return False
return True
Since I did not want to touch the s
, I declared new_s
to store alpha numeric characters. Here are steps I went through to solve the problem.
Check each character whether it is alpha numeric with
isalnum()
method. IfTrue
, add the character tonew_s
in lower caseCheck if the string is empty
Check characters in
new_s
from the start and from the end at the same time. The checking will continue until it reaches the middle withrange(len(new_s)//2)
. If the length is odd, the rest after dividing the length of the sentence by 2 will be discarded, since it is unnecessary to consider the character right in the middle.If the current position(left side) as
new_s[i]
and the other current position(right side)new_s[-(i+1)]
are not equal, it means no palindrome thus returnFalse
, otherwise returnTrue
Reflection
Palindrome, to me, is always something that excites me, perhaps all problems related to string control do excite me.
I at first was solving the problem by checking alpha numeric characters in ascii value comparison like, if (c.lower() >= "a" and c.lower() <= "z") or (c.lower() >= "0" and c.lower() <= "9"):
. I am not sure if it is common to compare and check the characters in this way, but I did it anyways. But then I found out that there is a method isalnum()
as an internal python library and wrote this code down. I thought this would give me some time efficiency when using the method but it was nothing of a difference. It just makes the code look simpler.
Subscribe to my newsletter
Read articles from Ramhee Yeon directly inside your inbox. Subscribe to the newsletter, and don't miss out.
Written by

Ramhee Yeon
Ramhee Yeon
South Korean, master's degree of AI. Programmer for LLM, app and web development. I am seeking opportunities to go to the USA and Canada, and Europe. I used to live in Frankfurt, Moscow, Pretoria, Baguio. Where to next?