給出一個 32 位的有符號整數,你需要將這個整數中每位上的數字進行反轉。
示例 1:
輸入: 123
輸出: 321
注意:
假設我們的環境只能存儲得下 32 位的有符號整數,則其數值范圍為 [−231, 231 − 1]。請根據這個假設,如果反轉后整數溢出那么就返回 0。int型的數值范圍是 -2147483648~2147483647, 那么如果我們要翻轉 1000000009 這個在范圍內的數得到 9000000001,而翻轉后的數就超過了范圍
Java解法:
class Solution { public int reverse(int x) { long result = 0; while (x != 0){ result = result * 10 + x % 10; x = x / 10; } if (result > Integer.MAX_VALUE || result < Integer.MIN_VALUE){ return 0; } return (int)result; } }