简单-整数反转

  • 给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。
    示例 1: 输入: 123 输出: 321
    示例 2: 输入: -123 输出: -321
    示例 3: 输入: 120 输出: 21
    注意: 假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−2^31, 2^31 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。
 // 整数翻转
func Reverse(x int) int {
    var tempStr string
    isNegative := false

    if x < 0 {
        tempStr = strconv.Itoa(0 - x)
        isNegative = true
    } else {
        tempStr = strconv.Itoa(x)
    }

    runes := []rune(tempStr)
    for i, j := 0, len(runes)-1; i < j; i, j = i+1, j-1 {
        runes[i], runes[j] = runes[j], runes[i]
    }
    res, err := strconv.Atoi(string(runes))
    if err != nil {
        panic("false")
    }
    if isNegative {
        if res > math.MaxInt32 {
            return 0
        }
        return 0 - res
    }else {
        if res > math.MaxInt32-1 {
            return 0
        }
        return res
    }
}

你可能感兴趣的:(简单-整数反转)