Given an integer
x is palindrome integer.
An integer is a palindrome when it reads the same backward as forward.
- For example,
121is a palindrome while
Input: x = 121
Explanation: 121 reads as 121 from left to right and from right to left.
Input: x = -121
Explanation: From left to right, it reads -121. From right to left, it becomes 121-. Therefore it is not a palindrome.
Input: x = 10
Explanation: Reads 01 from right to left. Therefore it is not a palindrome.
-231 <= x <= 231 - 1
Follow up: Could you solve it without converting the integer to a string?
Three different solutions with three different time complexities
Where n is the number of digits. The reversing of a string will take n steps.
Where n is the number of digits.
O(Log base 10 (n))
Where n is the number itself, in the below program we are trying to get the half number of the actual number, and on each loop, we are dividing out input by 10. In other words how many times do we have to divide n by 10 in order to get its half number