7. Reverse Integer

題目:

Given a 32-bit signed integer, reverse digits of an integer.
Example 1:
Input: 123
Output: 321
Example 2:
Input: -123
Output: -321
Example 3:
Input: 120
Output: 21
Note:
Assume we are dealing with an environment which could only hold integers within the 32-bit signed integer range. For the purpose of this problem, assume that your function returns 0 when the reversed integer overflows.


解法 1

class Solution:
    def reverse(self, x):
        """
        :type x: int
        :rtype: int
        """
        if x == 0:
            return x
        else:
            x = str(x)
            if '-' in x:
                x = int('-'+''.join(reversed(x[1::])))
            else:
                x = reversed(x)
                x = int(''.join(x))
            if abs(x) > 2**31:
                return 0
            else:
                return x

解法 2

def reverse(self, x):
    s = str(x)
    res = int('-' + s[1:][::-1]) if s[0] == '-' else int(s[::-1])
    return res if -2147483648 <= res <= 2147483647 else 0
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章