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;
    }
}