题目:(JAVA)给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。
基本要求:
我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−231, 231 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。
代码实现:
这里主要运用了方法的调用,详细的代码解析请观看代码块。
public static void main(String[] args) {
int a=reverse(666); //方法调用
System.out.println(a);
}
public static int reverse(int x) {
int remain; //定义一个变量,获得数字上的每一个数
int temp=0; //初始化为0,用来表示颠倒后的数
//只要数据不是0,就会一直进入循环
while(x!=0){
remain=x%10;
x=x/10;
//判断数据是否在正数的范围内
if(temp>Integer.MAX_VALUE/10 || (temp == Integer.MAX_VALUE && remain>7))
return 0;
//判断数据是否超出了负数范围
if(temp<Integer.MIN_VALUE/10 || (temp == Integer.MIN_VALUE && remain<-8))
return 0;
//在范围内,则进行颠倒计算,每执行一次,将上一次的执行结果扩大10倍,在加上新获得的remain,就可以实现颠倒。
temp=temp*10+remain;
}
return temp;
}