7. Reverse Integer

Description

Given a 32-bit signed integer, reverse digits of an integer.

Example 1:

Input: 123
Output: 321

Example 2:

Input: -123
Output: -321

Example 3:

Input: 120
Output: 21

Note:
Assume we are dealing with an environment which could only store integers within the 32-bit signed integer range: [−231, 231 − 1]. For the purpose of this problem, assume that your function returns 0 when the reversed integer overflows.

Solution

Use long

class Solution {
    public int reverse(int x) {
        int sign = x < 0 ? -1 : 1;
        long a = Math.abs((long) x);
        long b = 0;
        
        while (a > 0) {
            b = 10 * b + a % 10;
            a /= 10;
        }
        
        b *= sign;
        if (b > Integer.MAX_VALUE || b < Integer.MIN_VALUE) {
            return 0;
        }
        
        return (int) b;
    }
}

Detect overflow while iterating

利用overflow会有损耗的特点,通过revert方程来判断。

class Solution {
    public int reverse(int x) {
        int res = 0;
        
        while (x != 0) {
            int tail = x % 10;
            int newRes = 10 * res + tail;
            
            if ((newRes - tail) / 10 != res) {  // overflow
                return 0;
            }
            
            x /= 10;
            res = newRes;
        }
        
        return res;
    }
}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容