js 求解《初级算法》7.整数反转

该问题要求反转一个32位有符号整数的数字部分,但需考虑反转后是否超出[-2^31,2^31-1]范围。解决方案包括将整数转为绝对值字符串,分割数组,反转数组,重新拼接,并根据原始符号还原,最后检查结果是否在合法范围内。
摘要由CSDN通过智能技术生成

一. 题目描述

        给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。如果反转后整数超过 32 位的有符号整数的范围 [−231,  231 − 1] ,就返回 0。假设环境不允许存储 64 位整数(有符号或无符号)。

输入:x = 120

输出:21

输入:x = -123

输出:-321

输入:x = 0

输出:0

二、思路

        这道题有点小坑,就是最后需要处理数的范围哈哈,属于是没有看好题目了,他的原理就是需要把该整数先取绝对值,再转化为字符串,用split()方法将其分割为一个数组,再反转,最后把他拼接回去,把符号还给他,然后就是处理整数的范围了

三、代码展示

var reverse = function(x) {
  var nums = String(Math.abs(x))   // 返回绝对值 再转化为String对象
  var arr = nums.split('')         // 分割成数组
  nums = arr.reverse().join('')    // 再反转数组,最后重新拼接
  x = x>0?nums:-nums               // 判断正负 还原符号
  if(x > Math.pow(2,31)-1 || x < -Math.pow(2,31)){
      return 0
  }else{
      return x 
  }
};

四、回顾

如果发现自己对数组对象的原生方法不熟悉,可以去看看小糖往期的博客~干货食用链接:js数组对象 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值