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