在javascript中反转十进制数字

问题描述

| 如何使用按位反转数字? 输入:
x = 123; 
输出:
x = 321; 
怎么做?     

解决方法

        如果要进行简单的冲销:
var x = 123;
var y = x.toString();
var z = y.split(\"\").reverse().join(\"\");
var aa = Number(z);
document.write(aa);
http://jsfiddle.net/jasongennaro/gV39e/     ,        那不是反转位;颠倒了十进制数字的顺序,这是完全不同的。这是一种方法:
var x = 123;
var y = 0;
for(; x; x = Math.floor(x / 10)) {
    y *= 10;
    y += x % 10;
}
x = y;
如果您确实想反转位,则:
x = ~x;
作为功​​能:
function reverse(n) {
    for(var r = 0; n; n = Math.floor(n / 10)) {
        r *= 10;
        r += n % 10;
    }
    return r;
}
    ,        这是另一种方式
var reversed = num.toString().split(\'\').reverse().join(\'\');
jsFiddle。 如果您想再次将其作为it7 use,请使用
parseInt(reversed,10)
。但是请记住,前9个小数在十进制数中并不重要,如果转换为7个,将会丢失它们。     ,           您也使用此功能
function myfunction(a){
   var x=a.toString();
   var y= x.split(\"\");
   var z=y.reverse();
   var result=z.join(\"\");
     return result;
} myfunction(123);     ,        简单快速的解决方案:假设您要反转一个数字4546。将每个除数除以10,然后将其附加到结果中,直到数字>0。然后通过除以更新num变量到10点
var x = \'\';
var num = 4546;
while(num>0){
 x = x + (num%10);
 num = parseInt(num/10);
}
console.log(x);
    ,           反转正/负整数
function reverseInt(n) {
 return parseInt(n.toString().split(\'\').reverse().join()) * Math.sign(n)
}
  如果n为-5,则Math.sign(n)==>将返回-1      如果n为5,则Math.sign(n)==>将返回1     ,        这是JavaScript中可处理整数或字符串的可逆数组函数:
function reverse(array)
{
    var left = null;
    var right = null;
    var length = array.length;
    for (left = 0,right = length - 1; left < right; left += 1,right -= 1)
    {
        var temporary = array[left];
        array[left] = array[right];
        array[right] = temporary;
    }
    return array;
}

function toDigitsArrayFromInteger(integer,isReverse)
{
    var digits = [];

    if (integer > 0)
    {
        var floor = window.Math.floor;
        while (integer > 0)
        {
            digits.push(floor(integer % 10));
            integer = floor(integer / 10);
        }

        // Array is populated in reverse order. Un-reverse it to make it normal.
        if (!isReverse)
        {
            digits = reverse(digits);
        }
    }
    else if (integer < 0)
    {
        digits = toDigitsArrayFromInteger(-integer,isReverse);
    }
    else if (integer === 0)
    {
        digits.push(0);
    }

    return digits;
}

function toDigitsArrayFromString(string,isReverse)
{
    var digits = [];

    string += \"\"; // Coerce to string.

    var i = null;
    var length = string.length;
    for (i = 0; i < length; i += 1)
    {
        var integer = parseInt(string.charAt(i),10);
        if (isFinite(integer))
        {
            digits.push(integer);
        }
    }

    if (isReverse)
    {
        digits = reverse(digits);
    }

    return digits;
}
一旦将数字作为数组,您就可以轻松地反转数组,以使数字从左或从右开始。 字符串函数用途更广泛,因为它可以找到字符串中的任何数字,而整数函数则限于整数。 基准测试: http://jsperf.com/todigitsarray 这两个函数之间的基准测试表明,在Firefox 10和Chrome 12中,字符串函数比整数函数快30%到60%。在Opera 12中,整数函数稍微快了大约10%。     ,        
//reverse integer
const revInt = (num)=>{
  //turn into string
  if(Math.sign(num)===1)
    return parseInt(num.toString().split(\'\').reverse().join(\'\'));
  else return -1*parseInt(num.toString().split(\'\').reverse().join(\'\'));
}

console.log(revInt(-501));
    ,        
<html>
<script>

function reverseInt(n){

        var r=0;
    while(n!=0){
        r*=10;
        r+=n%10;
        n=Math.floor(n/10);
}
return r;
}


</script>
</html>
    ,        尝试这个
var n = 352;
function loop(n,r){
    if(!n) return r;
    r = (r ? r * 10 : 0) + n % 10;
    return loop(Math.floor( n / 10),r);
}
console.log(loop(n));
    ,        好的,如何在单行函数中使用和链接这些JavaScript中的流行技巧,如下所示...
const reverseNum = num => +(\"\" + ~~num.split(\"\").reverse().join(\"\"));
并这样称呼它:
reverseNum(123); //321
reverseNum(423.09); //324
reverseNum(23305.1); //50332
reverseNum(89112); //21198
reverseNum(568434.2389); //434865
    ,        它以
Number
x作为参数并返回相反的数字。
 const reverse = (x) => Number(x.toString().split(\"\").reverse().join(\"\"));
    ,        内存使用量:35.3 MB,不到leetcode.com上反向整数的JavaScript在线提交的100.00%。 运行时间:80毫秒,快于反向整数的JavaScript在线提交的61.48%。 时间复杂度为
O(log10(n))
function reverse(x) {
  let rev = 0;
  const isNegative = Math.sign(x) === -1;
  const isOverflow = n => n > 2**31;
  x = Math.abs(x);

  while (x) {
    let pop = x % 10;
    x = Math.floor(x / 10);
    rev = rev * 10 + pop;

    if (isOverflow(rev)) {
      return 0;
    } 
  }

  return isNegative ? rev * -1 : rev;
}
    ,        下面的代码块应该可以解决问题
<script type = \"text/javascript\">

var input;

input=window.prompt (\"Please enter a number to be reversed.\");
x=input.length;

while(x > 0)
{

x=x-1;
document.write(input[x]);

}

</script>
    

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...