Given a 32-bit signed integer, reverse digits of an integer.
Example 1:
Input: 123 Output: 321
Example 2:
Input: -123 Output: -321
Example 3:
Input: 120 Output: 21
Note:
Assume we are dealing with an environment which could only hold integers within the 32-bit signed integer range. For the purpose of this problem, assume that your function returns 0 when the reversed integer overflows.
#include <stdio.h>
#include <limits.h>
int reverse(int x){
int a;
long r;
a = (x < 0) ? -x : x;
r = 0;
while(a > 0){
r = r * 10 + a % 10;
a = a / 10;
}
if(r < INT_MIN || r > INT_MAX)
return 0;
if(x < 0)
return (-1) * r;
else
return r;
}
int main(void){
int num, x;
puts("Enter an integer:");
scanf("%d", &num);
x = reverse(num);
if(x)
printf("x = %d\n", x);
return 0;
}