day02--整数反转

2019-05-22  本文已影响0人  lyking

给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。

示例 1:

输入: 123
输出: 321
示例 2:

输入: -123
输出: -321
示例 3:

输入: 120
输出: 21
注意:

假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−231, 231 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。

class Solution {
    func reverse(_ x: Int) -> Int {
        var result = 0, temp = x
        while temp != 0 {
            let pop = temp % 10
            temp = temp / 10
            result = result * 10 + pop
            //处理溢出问题
            if result > Int32.max || (result == (Int32.max / 10) && pop > 7) {
                return 0
            }
            
            if result < Int32.min || (result == (Int32.min / 10) && pop < -8) {
                return 0
            }
        }
        
        return result
    }
}
上一篇下一篇

猜你喜欢

热点阅读