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月前
|
存储
LeetCode整数反转
解决LeetCode上的整数反转问题的几种方法,包括错误的方法和优化后的解决方案,以及如何避免反转后的整数超出32位有符号整数范围的问题。
35 1
|
3月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
115 2
|
1月前
【LeetCode】整数翻转
【LeetCode】整数翻转
16 1
|
1月前
|
存储 C++
Leetcode第十二题(整数转罗马数字)
LeetCode第12题“整数转罗马数字”的解题方法,包括罗马数字的基本规则和特殊规则,以及如何使用C++实现整数到罗马数字的转换。
16 0
|
1月前
|
C++
Leetcode第十三题(罗马数字转整数)
这篇文章介绍了LeetCode第13题“罗马数字转整数”的解题方法,通过一个C++的类`Solution`中的`romanToInt`函数来实现,该函数使用哈希表和遍历字符串的方法,根据罗马数字的规则将输入的罗马数字字符串转换为对应的整数值。
50 0
|
1月前
|
算法 C++
Leetcode第八题(字符串转换整数(atoi))
这篇文章介绍了LeetCode上第8题“字符串转换整数(atoi)”的解题思路和C++的实现方法,包括处理前导空格、正负号、连续数字字符以及整数溢出的情况。
18 0
|
3月前
|
算法
LeetCode第12题目整数转罗马数字
该文章介绍了 LeetCode 第 12 题整数转罗马数字的解法,通过使用 TreeMap 按照整数从大到小排序,先使用大的罗马数字表示整数,再用小的,核心是先表示完大的罗马数字,想通此点该题较简单。
LeetCode第12题目整数转罗马数字
|
3月前
|
算法
LeetCode第8题字符串转换整数 (atoi)
该文章介绍了 LeetCode 第 8 题字符串转换整数 (atoi)的解法,需要对字符串进行格式解析与校验,去除前导空格和处理正负号,通过从高位到低位的计算方式将字符串转换为整数,并处理越界情况。同时总结了这几道题都需要对数字的表示有理解。
LeetCode第8题字符串转换整数 (atoi)
|
3月前
|
算法
LeetCode第7题整数反转
该文章介绍了 LeetCode 第 7 题整数反转的解法,通过除 10 取模和乘 10 累加的方式实现整数反转,同时注意边界情况的判断,并总结了通过举例推算发现规律的解题思路。
LeetCode第7题整数反转
|
3月前
|
算法
LeetCode第13题目罗马数字转整数
该文章介绍了 LeetCode 第 13 题罗马数字转整数的解法,通过从大到小解析罗马数字,根据罗马数字的特点,按照从大到小的顺序匹配罗马数字和整数的关系,从而解决该问题,同时强调要注意观察题目考查的知识点特征。