Check if the given string is Palindrome or not in C

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 C.

Method 1: Using a Loop

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

#include <stdio.h>
#include <string.h>

int isPalindrome(char str[]) {
    int l = 0, r = strlen(str) - 1;
    while (l < r) {
        if (str[l] != str[r])
            return 0;
        l++, r--;
    }
    return 1;
}

int main() {
    char str[] = "madam";
    if (isPalindrome(str))
        printf("Palindrome\n");
    else
        printf("Not a Palindrome\n");
    return 0;
}
            
Input: madam
Output: Palindrome

Method 2: Using Recursion

This method checks palindrome property recursively.

#include <stdio.h>
#include <string.h>

int isPalindromeRecursive(char str[], int l, int r) {
    if (l >= r) return 1;
    if (str[l] != str[r]) return 0;
    return isPalindromeRecursive(str, l + 1, r - 1);
}

int main() {
    char str[] = "racecar";
    if (isPalindromeRecursive(str, 0, strlen(str) - 1))
        printf("Palindrome\n");
    else
        printf("Not a Palindrome\n");
    return 0;
}
            
Input: racecar
Output: Palindrome

Method 3: Using String Reverse

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

#include <stdio.h>
#include <string.h>

int main() {
    char str[] = "hello", rev[100];
    strcpy(rev, str);
    strrev(rev);
    if (strcmp(str, rev) == 0)
        printf("Palindrome\n");
    else
        printf("Not a Palindrome\n");
    return 0;
}
            
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