说明:现阶段的解题暂未考虑复杂度问题
Question:
Given a 32-bit signed integer, reverse digits of an integer.
Note:
Assume we are dealing with an environment which could only store integers within the 32-bit signed integer range: [−231, 231 − 1]. For the purpose of this problem, assume that your function returns 0 when the reversed integer overflows.
中文题目:
给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。
注意:
假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为[−2^31, 2^31− 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。
Example:
Input: 123
Output: 321
Input: -123
Output: -321
Input: 120
Output: 21
个人分析:
- 关键点:「
整数
」、「有符号
」、「取值范围
」、「反转后整数溢出返回 0
」。 - 由于有取值范围,我们可以先求出上下限的值,可使用
Math
对象中的pow
方法(Math
是JS
内置对象,需要熟悉它)。 - 看到题目中「
反转
」一词,应该很容易想到数组中有个reverse
反转函数,然后,字符串的split
方法可以将字符串转为数组,在转字符串时toString
方法应该用的比较多。 - 因为输入值可正可负,我们可以先求绝对值,使用
Math.abs()
, 然后通过第 3 步取反。 - 判断输入值的正负,决定输出值的符号。
- 判断反转值和上下限的大小,如果超出范围直接返回 0。
- 得出如下答案。
Answer:
var reverse = function(x) {
var max = Math.pow(2, 31) - 1
var min = Math.pow(-2, 31)
var reverseX = Number(Math.abs(x).toString().split('').reverse().join(''))
if (x > 0) {
if (reverseX > max) {
return 0
} else {
return reverseX
}
} else {
if (-reverseX < min) {
return 0
} else {
return -reverseX
}
}
};
其他:
本题更多 JavaScript
解析,点击链接访问对应的答案:https://leetcode.com