題目:
給出一個 32 位的有符號整數,你需要將這個整數中每位上的數字進行反轉。
示例 1:
輸入: 123
輸出: 321
示例 2:
輸入: -123
輸出: -321
示例 3:
輸入: 120
輸出: 21
注意:
假設我們的環境只能存儲得下 32 位的有符號整數,則其數值範圍爲 [−231, 231 − 1]。請根據這個假設,如果反轉後整數溢出那麼就返回 0。
解析:
方法一:轉字符串反轉
var reverse = function (x) {
x=x.toString();
var res=x.split("").reverse().join("");
res = parseInt(res);
if(res>2**31-1){
return 0;
}
return x < 0 ? -res:res;
};
方法二:循環遍歷取餘數
var reverse = function (x) {
var max = Math.pow(2, 31) - 1;
var min = -Math.pow(2, 31);
var res = 0;
while (x !== 0) {
res = 10 * res + x % 10;
x = ~~(x / 10);
}
if (res > max || res < min) {
return 0;
}
return res;
}