【刷穿 LeetCode】7. 整数反转(简单)

简介: 【刷穿 LeetCode】7. 整数反转(简单)

点击 这里 可以查看更多算法面试相关内容~


题目描述


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


注意:


假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为

[−231−2^{31}231,  2312^{31}231 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。


示例 1


输入:x = 12 输出:321


示例 2:


输入:x = -123 输出:-321


示例 3:


输入:x = 120 输出:21


示例 4:


输入:x = 0 输出:0


提示:


  • -2^31 <= x <= 2^31 - 1


不完美解法


还记得我在 【刷穿 LeetCode】4. 寻找两个正序数组的中位数 教过你的技巧吗?


在机试或者周赛这种需要快速 AC 的场景中,遇到这种从文字上进行限制的题目,可以选择性的忽略限制。


对于本题,题目从文字上限制我们只能使用 32 位的数据结构(int)。


但由于数据范围过大,使用 int 会有溢出的风险,所以我们使用 long 来进行计算,在返回再转换为 int :


class Solution {
    public int reverse(int x) {
        long ans = 0;
        while (x != 0) {
            ans = ans * 10 + x % 10;
            x = x / 10;
        }
        return (int)ans == ans ? (int)ans : 0;
    }
}
复制代码


时间复杂度:数字 x 的位数,数字大约有 log⁡10x\log{10}{x}log10x 位。复杂度为 log⁡10x\log{10}{x}log10x


空间复杂度:O(1)O(1)O(1)


完美解法


在「不完美解法」中,我们使用了不符合文字限制的 long 数据结构。


接下来我们看看,不使用 long 该如何求解。


从上述解法来看,我们在循环的 ans = ans * 10 + x % 10 这一步会有溢出的风险,因此我们需要边遍历边判断是否溢出:


  • 对于正数而言:溢出意味着 ans * 10 + x % 10 > Integer.MAX_VALUE,对等式进行变化后可得 ans > (Integer.MAX_VALUE - x % 10) / 10)。所以我们可以根据此变形公式进行预判断
  • 对于负数而言:溢出意味着 ans * 10 + x % 10 < Integer.MIN_VALUE,对等式进行变化后可得 ans < (Integer.MIN_VALUE - x % 10) / 10)。所以我们可以根据此变形公式进行预判断


class Solution {
    public int reverse(int x) {
        int ans = 0;
        while (x != 0) {
            if (x > 0 && ans > (Integer.MAX_VALUE - x % 10) / 10) return 0;
            if (x < 0 && ans < (Integer.MIN_VALUE - x % 10) / 10) return 0;
            ans = ans * 10 + x % 10;
            x /= 10;
        }
        return ans;
    }
}
复制代码


时间复杂度:数字 x 的位数,数字大约有 log⁡10x\log{10}{x}log10x 位。复杂度为 log⁡10x\log{10}{x}log10x


空间复杂度:O(1)O(1)O(1)


最后


这是我们「刷穿 LeetCode」系列文章的第 No.7 篇,系列开始于 2021/01/01,截止于起始日 LeetCode 上共有 1916 道题目,部分是有锁题,我们将先将所有不带锁的题目刷完。


在这个系列文章里面,除了讲解解题思路以外,还会尽可能给出最为简洁的代码。如果涉及通解还会相应的代码模板。


由于 LeetCode 的题目随着周赛 & 双周赛不断增加,为了方便我们统计进度,我们将按照系列起始时的总题数作为分母,完成的题目作为分子,进行进度计算。当前进度为 7/1916


为了方便各位同学能够电脑上进行调试和提交代码,我建立了相关的仓库:Github 地址 & Gitee 地址


在仓库地址里,你可以看到系列文章的题解链接、系列文章的相应代码、LeetCode 原题链接和一些其他的优选题解。


#算法与数据结构


#LeetCode题解


#算法面试


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