-
Notifications
You must be signed in to change notification settings - Fork 86
Open
Description
原题链接:
https://leetcode.cn/problems/reverse-integer
解题思路:
- 使用
result
存储反转后结果,初始值为0
。 - 每次循环取出
x
的个位数curr
,再将x
向右移动一位。 - 将
result
向左移动一位,并将curr
存入result
的个位数。 - 不断循环直到
x
为0
,即可完成反转。 x
为负数时,正整数部分的反转结果与正数是一样的。因此可以将x
都转为正整数处理,完成后再判断是否需要返回负数。
/**
* @param {number} x
* @return {number}
*/
var reverse = function (x) {
let result = 0; // 储存结果
// 正负数除了符号以外,处理结果是一样的,因此都转换为正数处理
let pos = x > 0 ? x : Math.abs(x);
// 不断循环直到pos为0
while (pos !== 0) {
// 取出pos的个位数字
const curr = pos % 10;
// 将result向左移动一位,将curr存入result的个位,完成一次反转
result = result * 10 + curr;
// 将pos向右移动一位,并去除小数
pos = Math.floor(pos / 10);
// 如果移动后的结果大于2^31 − 1,则返回0
if (result > 0x7fffffff) {
return 0;
}
}
// 判断x的正负,并返回相应结果
return x > 0 ? result : -result;
};
Metadata
Metadata
Assignees
Labels
No labels