Go解算法07整數反轉
描述
給出一個 32 位的有符號整數,你需要將這個整數中每位上的數字進行反轉。
示例 1:
輸入: 123
輸出: 321
示例 2:
輸入: -123
輸出: -321
示例 3:
輸入: 120
輸出: 21
注意:
假設我們的環境只能存儲得下 32 位的有符號整數,則其數值范圍為 [?231, 231 ? 1]。請根據這個假設,如果反轉后整數溢出那么就返回 0。
代碼
package main
import "fmt"
func main() {
fmt.Println(reverse(123))
}
func reverse(x int) int {
y := 0
for x != 0 {
y = y*10 + x%10
if (-(1 << 31) >= y) || (y >= (1<<31)-1) {
return 0
}
x /= 10
}
return y
}
我的博客即將同步至騰訊云+社區,邀請大家一同入駐:https://cloud.tencent.com/developer/support-plan?invite_code=hdru23bnu0gs
Go語言組件學習示例開源庫,歡迎star
https://github.com/EnochZg/golang-examples

浙公網安備 33010602011771號