Check if the given string is Palindrome or not in Python

Understanding Palindrome

A palindrome is a string that reads the same forward and backward.

We will explore three different methods to check if a string is a palindrome using Python.

Method 1: Using a Loop

This method iterates through the string and checks if it is a palindrome.

def is_palindrome(s):
    l, r = 0, len(s) - 1
    while l < r:
        if s[l] != s[r]:
            return False
        l += 1
        r -= 1
    return True

# Example usage
s = "madam"
print("Palindrome" if is_palindrome(s) else "Not a Palindrome")
            
Input: madam
Output: Palindrome

Method 2: Using Recursion

This method checks palindrome property recursively.

def is_palindrome_recursive(s, l, r):
    if l >= r:
        return True
    if s[l] != s[r]:
        return False
    return is_palindrome_recursive(s, l + 1, r - 1)

# Example usage
s = "racecar"
print("Palindrome" if is_palindrome_recursive(s, 0, len(s) - 1) else "Not a Palindrome")
            
Input: racecar
Output: Palindrome

Method 3: Using String Reverse

This method reverses the string and compares it with the original.

s = "hello"
rev = s[::-1]
print("Palindrome" if s == rev else "Not a Palindrome")
            
Input: hello
Output: Not a Palindrome
Strings

Below You will find some of the most important codes in languages like C, C++, Java, and Python. These codes are of prime importance for college semester exams and online tests.

Getting Started

Check whether a character is a vowel or consonant: C C++ Java Python

Check whether a character is an alphabet or not: C C++ Java Python

Find the ASCII value of a character: C C++ Java Python

Length of the string without using strlen() function: C C++ Java Python

Toggle each character in a string: C C++ Java Python

Count the number of vowels: C C++ Java Python

Remove the vowels from a string: C C++ Java Python

Check if the given string is Palindrome or not: C C++ Java Python

Print the given string in reverse order: C C++ Java Python

Remove all characters from string except alphabets: C C++ Java Python

Remove spaces from a string: C C++ Java Python

Replace a sub-string in a string: C C++ Java Python

Count common sub-sequences in two strings: C C++ Java Python

Compare two strings with wildcard support in one of them: C C++ Java Python

List all permutations of a given string in dictionary order: C C++ Java Python

Operations on Strings: C C++ Java Python