[LeetCode] 反转整数

时间:2023-03-09 04:52:15
[LeetCode] 反转整数

题目:

给定一个 32 位有符号整数,将整数中的数字进行反转。

示例 1:

输入: 123
输出: 321
示例 2: 输入: -123
输出: -321
示例 3: 输入: 120
输出: 21
注意: 假设我们的环境只能存储 32 位有符号整数,其数值范围是 [−231, 231 − 1]。根据这个假设,如果反转后的整数溢出,则返回 0。

  

思路:

我没有想更多的办法,因为以前用过StringBuffer里面的reserve方法,索性这里也试试

反转之后听过Integer.parseInt转为整数,然后catch异常,有异常就说明溢出,返回0

代码:

int t = Math.abs(x);
StringBuffer s = new StringBuffer();
s.append(t);
int a = x < 0?-1:1;
try {
a = a * Integer.parseInt(s.reverse().toString());
}catch (Exception e){
return 0;
}
return a;

  

效果还不错,30ms

[LeetCode] 反转整数