题目:
给定一个 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