Posted on

Description

Determine whether an integer is a palindrome. An integer is a palindrome when it reads the same backward as forward.

Example 1:

Input: 121
Output: true

Example 2:

Input: -121
Output: false
Explanation: From left to right, it reads -121. From right to left, it becomes 121-. Therefore it is not a palindrome.

Example 3:

Input: 10
Output: false
Explanation: Reads 01 from right to left. Therefore it is not a palindrome.

Follow up:

Could you solveĀ it without converting the integer to a string?

Submission

Simple but Not Meet the Requirement

A straightforward solution is to convert the number into a string and then from both sides check if the string is symmetric.

class Solution {
    public boolean isPalindrome(int x) {
        String s = Integer.toString(x);
        if(s.length() <= 1) return true;
        for(int i = 0; i <= s.length() / 2; i++) {
            if(s.charAt(i) != s.charAt(s.length() - 1 - i)) return false;
        }
        
        return true;
    }
}

The Desired Answer

The following one is written in an Integer manner, slightly faster than the previous one and does not convert the number to a string prior to the comparison.

class Solution {
    public boolean isPalindrome(int x) {
        if(x < 0 || (x % 10 == 0 && x != 0)) return false;
        
        int reversed = 0;
        while(x > reversed) {
            reversed = reversed * 10 + x % 10;
            x /= 10;
        }
        
        return x == reversed || x == reversed / 10;
    }
}

Leave a Reply

Your email address will not be published. Required fields are marked *