Java program to check whether a string is a Palindrome

Given a string str, the task is to find whether the string is a palindrome or not in Java without using library methods.


Input: str = “abba”
Output: Yes

Input: str = “geeks”
Output: No

Approach: Take two pointers i pointing to the start of the string and j pointing to the end of the string. Keep incrementing i and decrementing j while i < j and at every step check whether the characters at these pointers are same or not. If not then the string is not a palindrome else it is.

Below is the implementation of the above approach:





// Java implementation of the approach
public class GFG {
    // Function that returns true if
    // str is a palindrome
    static boolean isPalindrome(String str)
        // Pointers pointing to the beginning
        // and the end of the string
        int i = 0, j = str.length() - 1;
        // While there are characters toc compare
        while (i < j) {
            // If there is a mismatch
            if (str.charAt(i) != str.charAt(j))
                return false;
            // Increment first pointer and
            // decrement the other
        // Given string is a palindrome
        return true;
    // Driver code
    public static void main(String[] args)
        String str = "geeks";
        if (isPalindrome(str))




Attention reader! Don’t stop learning now. Get hold of all the important Java and Collections concepts with the Fundamentals of Java and Java Collections Course at a student-friendly price and become industry ready.

My Personal Notes arrow_drop_up

Check out this Author's contributed articles.

If you like GeeksforGeeks and would like to contribute, you can also write an article using or mail your article to See your article appearing on the GeeksforGeeks main page and help other Geeks.

Please Improve this article if you find anything incorrect by clicking on the "Improve Article" button below.

Improved By : nishantv