给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。
如果反转后整数超过 32 位的有符号整数的范围 [−2^31, 2^31 − 1] ,就返回 0。
假设环境不允许存储 64 位整数(有符号或无符号)。
示例
输入:x = -123 输出:-321
输入:x = 120 输出:21
解析
1)这道题如果没有不能超过32位存储空间的限制,就会很简单,用字符串翻转即可;
2)考虑到空间限制,就得从31位考虑,如果去掉各位数,大于 2**31//10,就要进一步判断各位数的大小。
代码示例
class Solution: def reverse(self, x: int) -> int: ans = 0 x_ = abs(x) while x_ != 0: x_, m = divmod(x_, 10) if ans > 2**31//10: return 0 if ans == 2**31//10 and x>0 and m>2**31%10-1: return 0 if ans == 2**31//10 and x<0 and m>2**31%10: return 0 ans = ans * 10 + m # 实现翻转的主要逻辑 return ans if x>0 else -ans
执行用时:32 ms, 在所有 Python3 提交中击败了 93.81% 的用户.
本文为 陈华 原创,欢迎转载,但请注明出处:http://ichenhua.cn/read/414