8

Infinity我正在尝试对有时具有or的数组进行排序NaN。当我使用标准 JavaScriptarray.sort()时,它似乎会排序,直到达到 a NaN,然后我得到随机结果。

var array =[.02,.2,-.2,Nan,Infinity,20];

有没有办法仍然对它进行排序,以便最终结果从负到正并且仍然有NaNorInfinity在最后。

-.2,.02,.2,20,NaN,Infinity
4

5 回答 5

13

如果您只想以随机顺序将它们撞到最后:

var arr = [-1, 0, 1, 10, NaN, 2, NaN, 0, -1, NaN, 5, Infinity, 0, -Infinity];

arr.sort(function(a,b){
    if( !isFinite(a) && !isFinite(b) ) {
        return 0;
    }
    if( !isFinite(a) ) {
        return 1;
    }
    if( !isFinite(b) ) {
        return -1;
    }
    return a-b;
});
//[-1, -1, 0, 0, 0, 1, 2, 5, 10, NaN, NaN, NaN, Infinity, -Infinity]

如果您还想在最后对无穷大进行排序:

var arr = [-1, 0, 1, 10, NaN, 2, NaN, 0, -1, NaN, 5, Infinity, 0, -Infinity];

arr.sort(function(a,b){
    if( !isFinite(a) && !isFinite(b) ) {
        return ( isNaN(a) && isNaN(b) )
            ? 1
            : a < b
                ? -1
                : a === b
                    ? 0
                    : 1;
    }
    if( !isFinite(a) ) {
        return 1;
    }
    if( !isFinite(b) ) {
        return -1;
    }
    return a-b;
});

//[-1, -1, 0, 0, 0, 1, 2, 5, 10, -Infinity, Infinity, NaN, NaN, NaN]

这里的顺序是-Infinity< Infinity<NaN

于 2013-07-09T21:05:51.417 回答
11

对于这些情况,您可以捕获NaNInfinity使用 JavaScript 的内置实用程序函数:

let array = [Infinity, -1, 6, 1, 0, NaN, 0, -1, 2, 5, 10, -Infinity, NaN, Infinity, NaN]



//sort -Infinity, NaN, Infinity to the end in random order
array.sort(function(a,b){
  if(isFinite(a-b)) {
    return a-b; 
  } else {
    return isFinite(a) ? -1 : 1;
  }
});

//[-1,-1,0,0,1,2,5,6,10,NaN,Infinity,Infinity,NaN,-Infinity,NaN]
console.log(array);



//sort -Infinity<0<Infinity<NaN
array.sort(function(a,b){
  if(isNaN(a)) { 
    return 1-isNaN(b);
  } else {
    return a-b; 
  }
});

//[-Infinity,-1,-1,0,0,1,2,5,6,10,Infinity,Infinity,NaN,NaN,NaN]
console.log(array);

于 2013-07-09T20:51:58.847 回答
9

负无穷大在逻辑上应该首先排序,因为它实际上小于所有其他数字。

因此,我会这样做:

const cmp = (a,b) => a-b || isNaN(a)-isNaN(b);

// Example
const arr = [Infinity, NaN, Infinity, -Infinity, NaN, 1, 0, NaN, -1, -0];
console.log(arr.sort(cmp));

于 2019-05-22T21:29:34.667 回答
0

像这样的东西?

var arr = [-1, 0, 1, 10, NaN, 2, NaN, 0, -1, NaN, 5, Infinity, 0];
function sortInf (a, b) {
    a = parseFloat(a);
    b = parseFloat(b);
    if ((!a || a === -Infinity) && a !== 0) {
        return 1;
    } else if ((!b || b === -Infinity) && b !== 0) {
        return -1;
    } else return a - b;
}
alert(arr.sort(sortInf));
于 2013-07-09T20:51:30.133 回答
-1

一种没有条件或函数开销的简单快速的方法:

var r=[1,9,NaN,3,4,5,0,-4, NaN , 4, Infinity, 7, 2];
 r.sort(function(a,b,c){return  a-b || (a||Infinity)-(b||Infinity) || 0 });
 alert(r) // == -4,0,1,2,3,4,4,5,7,9,NaN,NaN,Infinity

编辑:根据反馈进行更新以避免 NaN 返回。

这比其他答案的执行速度快约 20 倍,因此如果您需要性能,这是理想的选择,而排序是性能通常很重要的一个领域......

于 2013-07-09T21:16:38.523 回答