Reverse Integer - 反转一个int,溢出时返回0

本文介绍了如何使用Java实现反转整数的功能,并处理了溢出情况。通过代码实例,展示了正负数反转的方法及判断溢出的逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Reverse Integer

Reverse digits of an integer.

Example1: x = 123, return 321
Example2: x = -123, return -321

若反转的数溢出,直接返回0

可以用计算结果来判断溢出,也可以用因数来判断

Java代码实现:

 1 public class ReverseInteger {
 2     public static int reverseInt(int x){
 3         if (x == 0) {
 4             return 0;
 5         }
 6         int flag = -1;
 7         int result = 0;
 8         if (x < 0) {
 9             x = x * flag;
10             if (x < 0) {
11                 return 0;
12             }
13         } else {
14             flag = 1;
15         }
16         int digits = 1;
17         int temp = x;
18         while(temp/10 != 0){
19             digits++;
20             temp/=10;
21         }
22         //judge before calculate at every may out of range place
23         for (int i = 1; i <= digits; i++) {
24             int a,b;
25             a = (int) (x/Math.pow(10, i-1));
26             a = a%10;//get the single number
27             b = (int) Math.pow(10, digits-i);
28             if ((a*b<0) || (a > 2 && (digits - i) == 9)) {//use number to judge
29                 return 0;
30             } else {
31                 temp = a*b;
32             }
33             if (result + temp < 0) {//judge
34                 return 0;
35             } else {
36                 result += temp;
37             }
38         }
39         return result*flag;
40     }
41     public static void main(String args[]){
42         int max = 2147483647;
43         int min = -2147483648;
44         System.out.println(reverseInt(0));
45         System.out.println(reverseInt(1534236469));
46         System.out.println(reverseInt(-2133847412));
47     }
48 }

输出:

0
0
-2147483312

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值