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