2020-05-22 17:57:23 +08:00
|
|
|
def is_palindrome(s: str) -> bool:
|
2020-04-20 00:35:36 +08:00
|
|
|
"""
|
|
|
|
Determine whether the string is palindrome
|
|
|
|
:param s:
|
|
|
|
:return: Boolean
|
|
|
|
>>> is_palindrome("a man a plan a canal panama".replace(" ", ""))
|
|
|
|
True
|
|
|
|
>>> is_palindrome("Hello")
|
|
|
|
False
|
2020-05-22 17:57:23 +08:00
|
|
|
>>> is_palindrome("Able was I ere I saw Elba")
|
|
|
|
True
|
|
|
|
>>> is_palindrome("racecar")
|
|
|
|
True
|
|
|
|
>>> is_palindrome("Mr. Owl ate my metal worm?")
|
|
|
|
True
|
2020-04-20 00:35:36 +08:00
|
|
|
"""
|
2020-06-16 16:09:19 +08:00
|
|
|
# Since Punctuation, capitalization, and spaces are usually ignored while checking
|
|
|
|
# Palindrome, we first remove them from our string.
|
2020-05-22 17:57:23 +08:00
|
|
|
s = "".join([character for character in s.lower() if character.isalnum()])
|
2020-04-20 00:35:36 +08:00
|
|
|
return s == s[::-1]
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
s = input("Enter string to determine whether its palindrome or not: ").strip()
|
|
|
|
if is_palindrome(s):
|
|
|
|
print("Given string is palindrome")
|
|
|
|
else:
|
|
|
|
print("Given string is not palindrome")
|