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