LeetCode第七题整数反转

题目描述如下

给你一个 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

基本思路

对于负数,首先转成正数,然后就按照正数进行反转,最后*(-1)或者用0减去就可以了

代码如下

复制代码
class Solution(object):
    def reverse(self, x):
        """
        :type x: int
        :rtype: int
        """
        num = x
        total = 0
        a = -1
        if (num < 0):
            num = abs(num)
            while num>0:
                temp = num % 10
                num = num // 10
                total = total*10+temp
            total = a*total
        elif(num >= 0):
            while num>0:
                temp = num % 10
                num = num // 10
                total = total*10+temp
        if (2**31 -1 >total> -2**31):
            return total   
        else:
            return 0  
相关推荐
Swift社区4 分钟前
LeetCode 459 - 重复的子字符串
算法·leetcode·职场和发展
byzh_rc4 分钟前
[算法设计与分析-从入门到入土] 图遍历
算法·深度优先
小李小李快乐不已12 分钟前
动态规划理论基础
数据结构·c++·算法·leetcode·动态规划
leaves falling13 分钟前
c语言数组-求10 个整数中最大值
c语言·c++·算法
im_AMBER13 分钟前
数据结构 15 【复习】树和二叉树小结 | 图算法 | 拓扑排序 | AOE 网
数据结构·笔记·学习·算法·图论
ocean210315 分钟前
Linux面试题图解
linux·运维·服务器·面试·职场和发展
太理摆烂哥16 分钟前
数据结构之图
数据结构·算法
leaves falling19 分钟前
c语言-数1到100的所有整数中数字9出行的个数
c语言·开发语言·算法
圣保罗的大教堂20 分钟前
leetcode 1351. 统计有序矩阵中的负数 简单
leetcode
Tisfy23 分钟前
LeetCode 1351.统计有序矩阵中的负数:O(m+n)时间复杂度——抽象题解
算法·leetcode·矩阵·题解·遍历