题目描述:
给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。
示例 1: 输入: 123 输出: 321
示例 2: 输入: -123 输出: -321
示例 3: 输入: 120 输出: 21
简洁思路:
此题就跟判断数字是否为回文数的思路大致相同,依次取出整数的每一位数字给temp,再通过x/10使得数字依次减小十倍,通过result计算其反转后的数字。
注:运行过程中当x>1534236461时,返回值为0,故需要添加一个判断语句。
int reverse(int x) {
long temp,result=0;;
if(x>1534236461) return 0;
while(x){
temp=x%10;
x=x/10;
result=result*10+temp;
}
if(result>2147483642||result<(-2147483641)) return 0;
return result;
}