leetcode:7.整数反转

简介: 给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。

题目描述:


给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。


示例:


示例1:

输入: 123
输出: 321


示例2:


输入: -123
输出: -321


示例3:


输入: 120
输出: 21


注意:


假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−231, 231 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。


题目难度:简单

分析:


题目比较简单,利用除法和取余就可以完成,需要注意的是数值的范围,那么就需要知道在什么情况下反转的整数会溢出。

代码如下:


java:


class Solution {
    public int reverse(int x) {
      // 用来返回的结果
        int res = 0;
        // 需要对x进行取余和除法计算,只要x != 0就继续
        while (x != 0) {
          /* 这里不难想到,因为res每次都需要 * 10,
          所以当res > Integer.MAX_VALUE / 10时,再次 * 10 就会溢出,负数同理
          */
            if(res > Integer.MAX_VALUE / 10 || res < Integer.MIN_VALUE / 10)
                return 0;
            // 就一行核心代码:res每次 * 10 再 + 上 x 取模的值
            res = res * 10 + x % 10;
            // x 每次都要 / 10 ,少一位数
            x /= 10;
        }
        return res;
    }
}


python:


这里python和java不同的是负数的除法,需要注意


class Solution:
    def reverse(self, x: int) -> int:
        if x < 0:
            flag = -1
            x = -x
        else:
            flag = 1
        res = 0
        while x != 0:
            res = res * 10 + x % 10
            x //= 10
        res *= flag
        return res if res < 2 ** 31 -1 and res > -2 ** 31 else 0


总结:


时间复杂度为O(log 10 x),x中大约有l o g 10 x 位数字。(因为每次都要除10)。


每次遇到什么反转数字、字符串等,大多用这种思路,都是从后往前,只不过字符串是利用下标。

目录
相关文章
|
1月前
|
算法 Java
[Java·算法·简单] LeetCode 13. 罗马数字转整数 详细解读
[Java·算法·简单] LeetCode 13. 罗马数字转整数 详细解读
31 0
|
1月前
【Leetcode】两数之和,给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。
【Leetcode】两数之和,给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。
|
1天前
|
算法
力扣经典150题第十八题:整数转罗马数字
力扣经典150题第十八题:整数转罗马数字
4 0
|
1天前
|
存储 算法 测试技术
力扣经典150题第十七题:罗马数字转整数
力扣经典150题第十七题:罗马数字转整数
5 0
|
19天前
|
SQL 算法 数据挖掘
深入探索力扣第12题:整数转罗马数字的算法之旅
深入探索力扣第12题:整数转罗马数字的算法之旅
|
19天前
|
SQL 算法 数据可视化
LeetCode第八题:字符串转换整数 (atoi)【8/1000 python】
LeetCode第八题:字符串转换整数 (atoi)【8/1000 python】
|
1月前
[leetcode~数位动态规划] 2719. 统计整数数目 hard
[leetcode~数位动态规划] 2719. 统计整数数目 hard
|
1月前
|
存储
【力扣】7. 整数反转
【力扣】7. 整数反转
|
1月前
leetcode代码记录(整数拆分
leetcode代码记录(整数拆分
21 0
|
1月前
|
测试技术
【力扣】13. 罗马数字转整数、12. 整数转罗马数字
【力扣】13. 罗马数字转整数、12. 整数转罗马数字