给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。
示例 1: 输入: 123 输出: 321
示例 2: 输入: -123 输出: -321
示例 3: 输入: 120 输出: 21
注意:
假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−231, 231 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/reverse-integer
/**
* @param {number} x
* @return {number}
*/
var reverse = function (x) {
//判断正负
var flag = x < 0 ? -1 : 1;
//转为字符串拆分数组,反转数组,合并数组,恢复正负值
var num = parseInt(x.toString().split("").reverse().join("")) * flag;
//判断范围 超出返回0
if (num > 2 ** 31 - 1 || num < (-2) ** 31) return 0;
return num;
};
这是我自己的思路,感觉api用的比较多,不太好。
最后一次更新于2020-04-22
0 条评论