每日一练python25

题目:(整数反转)给你一个 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)

猜你喜欢

转载自blog.csdn.net/qq_52669357/article/details/121707996
今日推荐