给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。

给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。

示例 1:

 

 示例 2:

 

示例 3:

 

注意:

假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−231,  231 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。

 public static int reverse(int x) {
     StringBuffer sdf = new StringBuffer();
     sdf.append(x);
     sdf.reverse();
     if(String.valueOf(sdf.charAt(sdf.length() - 1)).equals("-")) {
         sdf.deleteCharAt(sdf.length() - 1);
         sdf.insert(0,"-");
     }
     int result = 0;
     try {
        result = Integer.parseInt(sdf.toString());
     }catch (Exception e) {
         return 0;
     }

     return result;
 }

 public static void main(String args[]) {
     int result = reverse(-123345678);
     System.out.println(result);
 }

你可能感兴趣的:(LeetCode)