給出一個 32 位的有符號整數,你需要將這個整數中每位上的數字進行反轉。
示例 1:
輸入: 123
輸出: 321
示例 2:
輸入: -123
輸出: -321
示例 3:
輸入: 120
輸出: 21
注意:
假設我們的環境只能存儲得下 32 位的有符號整數,則其數值範圍爲 [−231, 231 − 1]。請根據這個假設,如果反轉後整數溢出那麼就返回 0。
來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/reverse-integer
著作權歸領釦網絡所有。商業轉載請聯繫官方授權,非商業轉載請註明出處。
public class Solution
{
public int Reverse(int x)
{
int k = x;
int t = 0;
while (k != 0)
{
t = t * 10 + k % 10;
k = k / 10;
if (k != 0)
{
if ((Math.Pow(2, 31) - 1 - k % 10) / 10 <= t || (-1 * Math.Pow(2, 31) - k % 10) / 10 >= t)
{
return 0;
}
}
}
return t;
}
}
注意檢驗整數溢出的情況,該情況下不會報錯。