[LeetCode] 7. Reverse Integer 题解

栏目: 编程工具 · 发布时间: 5年前

内容简介:给定一个 32 位有符号整数,将每一位的数字反序注意:假设我们使用的是 32 位系统,且只能处理 范围的整数,当出现整型溢出时,你的程序返回 0

给定一个 32 位有符号整数,将每一位的数字反序

例1:

输入:123
输出:321
复制代码

例2:

输入:-123
输出:-321
复制代码

例3:

输入:120
输出:21
复制代码

注意:

假设我们使用的是 32 位系统,且只能处理 范围的整数,当出现整型溢出时,你的程序返回 0

问题难度

Easy

解题思路

首先这道题不适合使用 Python 来做,原因是面对负数时,Python 的行为与期望不符,例如

>>> -31/10
-3.1
>>> -31%10
9
复制代码

而使用 C++ 这样的语言,你会得到这样的结果

int main() {
	cout << "-3 / 10 = " << -3/10 << endl; 
	cout << "-3 % 10 = " << -3%10 << endl; 
}
输出:
-3 / 10 = 0
-3 % 10 = -3
复制代码

可以看到后者比较符合我们的预期。

另外此题的关键在于如何解决整数溢出,思路如下:

整数溢出不能在发生了之后才去判断,而只能在发生溢出之前判断,我们的算法是,将原数不断除以 10,把得到的余数再不断乘以 10 ,这样就可以将原数「反转」,我们可以形象的把除以 10 看作是原数的右移,而把乘以 10 看做是新数的左移;既然要在溢出之前判断,那么我们就需要先将整型的最大值或最小值除以 10,然后将结果和该值进行比较,如果发现进一步操作会发生溢出,则返回 0。

对于正数,我们知道其最大值是 ,所以如果结果 在下一次「左移」前大于 214748364,那么就一定会发生溢出;特殊情况是 在「左移」前等于 214748364,此时还需要判断下一个余数是否超过 7,如果超过,也可以判断其会发生溢出。

同理,负数也可以这样进行判断,这样我们就可以写出程序了:

#include <iostream>
#include <climits>
using namespace std;

int integer_reverse(long x) {
    int result = 0;
    while (x != 0) {
        int remainder = x % 10;
        x = x / 10;

        if (result > INT_MAX/10 || (result == INT_MAX/10 && remainder > 7)) return 0;
        if (result < INT_MIN/10 || (result == INT_MIN/10 && remainder < -8)) return 0;

        result = result * 10 + remainder;
    }

    return result;
}
复制代码

可以看到,两个 if 语句分别处理正数和负数两种情况,而 if 中的条件就包含了刚才说的两种溢出情况。

原题链接


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

多处理器编程的艺术

多处理器编程的艺术

(美)Maurice Herlihy、(美)Nir Shavit / 机械工业出版社 / 2013-2 / 79.00元

工业界称为多核的多处理器机器正迅速地渗入计算的各个领域。多处理器编程要求理解新型计算原理、算法及编程工具,至今很少有人能够精通这门编程艺术。 现今,大多数工程技术人员都是通过艰辛的反复实践、求助有经验的朋友来学习多处理器编程技巧。这本最新的权威著作致力于改变这种状况,作者全面阐述了多处理器编程的指导原则,介绍了编制高效的多处理器程序所必备的算法技术。了解本书所涵盖的多处理器编程关键问题将使在......一起来看看 《多处理器编程的艺术》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具