package com.sf.leetcode; public class Solution_7 { public static void main(String[] args) { System.out.println(Long.MAX_VALUE); System.out.println(Float.MAX_VALUE); System.out.println(Double.MAX_VALUE); } // 字符串解法 public int reverse(int x) { // 处理负数 if (x < 0) { if (x <= Integer.MIN_VALUE) return 0; // x -> 正数 -x -> 负数的返回 return -reverse(-x); } // 数字转字符串 String str = String.valueOf(x); // 字符数组 char[] charArray = str.toCharArray(); for (int i = 0; i < charArray.length / 2; i++) { char temp = charArray[i]; charArray[i] = charArray[charArray.length - i - 1]; charArray[charArray.length - i - 1] = temp; } // 当前的字符串是一个有效的数字 只是超出了int的范围 // 所有表示数值的类型 谁的范围最大 byte short int long float double String doubleStr = String.copyValueOf(charArray); double doubleNum = Double.parseDouble(doubleStr); return doubleNum > Integer.MAX_VALUE ? 0 : (int) doubleNum; } }