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

Posted cznczai

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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的取值范围为: -2^31——2^31-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的个位数*

以上是关于7.整数反转--数论(怎么判断溢出)的主要内容,如果未能解决你的问题,请参考以下文章

[LeetCode] 整数反转

7. Reverse Integer(反转整数)

7.整数反转Java版,每日一题系列(此题来自力扣网)

7.整数反转Java版,每日一题系列(此题来自力扣网)

7. 整数反转

7. 整数反转