• 7.整数反转--数论(怎么判断溢出)


    class Solution {
       public int reverse(int x) {
    		int flag = 1;
    		int ans = 0;
    		int temp = 0;
    		if (x < 0) { // 解决正负 符号位加入运算 现在需要解决的是溢出
    			flag = -1;
    			x *= -1;
    		}
    		while (x > 0) {
    			temp = x % 10;
    			if (ans > Integer.MAX_VALUE / 10 || (ans == Integer.MAX_VALUE / 10 && temp > 7))
    				return 0;
    			if (ans < Integer.MIN_VALUE / 10 || (ans == Integer.MIN_VALUE / 10 && temp < -8))
    				return 0;
    			ans = ans * 10 + temp;
    			x /= 10;
    		}
    		return ans * flag;
    	}
    }
    

    int的取值范围为: -231——231-1,即-2147483648——2147483647

    从ans 10 + pop > MAXVALUE这个溢出条件来看
    当出现 ans > MAXVALUE / 10 且 还有pop需要添加 时,则一定溢出
    当出现 ans == MAXVALUE / 10 且 pop > 7 时,则一定溢出,7是2^31 - 1的个位数
    从ans 10 + pop < MINVALUE这个溢出条件来看
    当出现 ans < MINVALUE / 10 且 还有pop需要添加 时,则一定溢出
    当出现 ans == MAXVALUE / 10 且 pop < -8 时,则一定溢出,8是-2^31的个位数*

    class Solution {
       public int reverse(int x) {
            int flag = 1;
           if(x<0){
               flag *=-1;
               x *=-1;
               }
            long res = 0 ;
            while(x>0){
                res = x %10 +res*10;
                x /= 10;
            }
           if(res>Integer.MAX_VALUE||res<Integer.MIN_VALUE)
               return 0;
           else return (int)res*flag;
       }
    }	
    
  • 相关阅读:
    java 常用第3方工具
    反射与内省
    UDP通讯协议实例
    多线程及线程并发库Executors
    Deque 双端队列 Stack 堆栈
    Collections工具类
    Map 接口
    PHP控制电脑重启 关机
    ThinkPHP框架研究之一 基本函数 M和D的区别
    textarea输入输出的处理
  • 原文地址:https://www.cnblogs.com/cznczai/p/11147887.html
Copyright © 2020-2023  润新知