Rohan Verma

Learning Machine Learning and other programming stuff

View on GitHub

Palindrome Number

Given an integer x, return true if x is a palindrome, and false otherwise.

Constraints

-231 <= x <= 231 - 1

Example 1

Input: x = 121
Output: true
Explanation: 121 reads as 121 from left to right and from right to left.

Example 2

Input: x = -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: x = 10
Output: false
Explanation: Reads 01 from right to left. Therefore it is not a palindrome.

Solution

First, the code checks if x is negative. If it is, then it cannot be a palindrome since the reverse of a negative number will not be equal to the original number. In such a case, the code returns False. If number is multi digit it reverses it and then checks if it is equal to original number or not.

Since we have set a baseline lets try to code it :

class Solution {
 public:
  bool isPalindrome(int x) {
    if (x < 0)
      return false;

    long reversed = 0;
    int y = x;

    while (y > 0) {
      reversed = reversed * 10 + y % 10;
      y /= 10;
    }

    return reversed == x;
  }
};
class Solution:
  def isPalindrome(self, x: int) -> bool:
    if x < 0:
      return False

    rev = 0
    y = x

    while y:
      rev = rev * 10 + y % 10
      y //= 10

    return rev == x