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  
相关推荐
Maỿbe23 分钟前
力扣hot图论部分
算法·leetcode·图论
LYFlied31 分钟前
【每日算法】LeetCode 78. 子集
数据结构·算法·leetcode·面试·职场和发展
月明长歌35 分钟前
【码道初阶】【Leetcode606】二叉树转字符串:前序遍历 + 括号精简规则,一次递归搞定
java·数据结构·算法·leetcode·二叉树
子枫秋月36 分钟前
C++字符串操作与迭代器解析
数据结构·算法
鹿角片ljp36 分钟前
力扣234.回文链表-反转后半链表
算法·leetcode·链表
(●—●)橘子……37 分钟前
记力扣1471.数组中的k个最强值 练习理解
数据结构·python·学习·算法·leetcode
oioihoii40 分钟前
C++共享内存小白入门指南
java·c++·算法
Bruce_kaizy42 分钟前
c++图论————图的基本与遍历
c++·算法·图论
l1t1 小时前
利用小米mimo为精确覆盖矩形问题C程序添加打乱函数求出更大的解
c语言·开发语言·javascript·人工智能·算法
亭上秋和景清1 小时前
strlen;strcpy ;strcat
算法