题目:给你一个 32 位的有符号整数 x ,返回将 x 中的数字局部反转后的后果。如果反转后整数超过 32 位的有符号整数的范畴 [−231, 231 − 1] ,就返回 0。

链接: 力扣LeetBook—高级算法—字符串—整数反转.

示例 1:

输出:x = 123
输入:321

示例 2:

输出:x = -123
输入:-321

示例 3:

输出:x = 120
输入:21

示例 4:

输出:x = 0
输入:0

标签:数学

留神:Go语言中符号 “ ^ ” 不再用于次方,而是示意“按位异或的运算”,so不能够用2^31示意,在这我就用了math.Pow函数

次要Go代码如下:

package mainimport (    "fmt"    "math")func reverse(x int) int {    sum := 0    for x != 0 {        a := x % 10        sum = sum*10 + a        x = x / 10        Max := int(math.Pow(2, 31) - 1)        Min := int(math.Pow(-2, 31) - 1)        if sum > Max || sum < Min {            return 0        }    }    return sum}func main() {    fmt.Println(reverse(321))}

提交截图