题目:(整数反转)给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。如果反转后整数超过 32 位的有符号整数的范围 [?231, 231 ? 1] ,就返回 0。假设环境不允许存储 64 位整数(有符号或无符号)。
示例 1:
输入:x = 123 输出:321 示例 2:
输入:x = -123 输出:-321 示例 3:
输入:x = 120 输出:21 示例 4:
输入:x = 0 输出:0
提示: -231 <= x <= 231 - 1
程序说明: 1、其实在刚开始看到题目时,我刚开始想到是运用abs函数先将负数取其绝对值,然后再逐渐对整数进行不断取余的操作,最后再根据简单的数学运算操作即可解决问题,但是会发现程序过于复杂,且可能会出现超时的情况,因此此方法不可行 2、下面的代码是先将整数化为字符串,再对字符串进行操作。先定义了一个初始字符串,用于最后输出,判读是否有负号的字符串出现,若有则将其加入到初始化的字符串中去。若出现0,则去掉反转之后的第一个0并去掉尾部的负号,最后再将字符串化为整型,对其进行范围判断。 全部代码:
class Solution:
def reverse(self, x: int) -> int:
if x==0:
return 0
strs=str(x)
x=''
if strs[0]=='-':
x=x+'-'
x+=strs[len(strs)-1::-1].lstrip("0").rstrip("-")
x=int(x)
if -2**31< x <2**31-1:
return x
return 0
题目来源:力扣(LeetCode)
|