如何在JavaScript中对浮点数组进行排序

How to sort an array of floats in JavaScript?

本文关键字:数组 排序 JavaScript      更新时间:2023-09-26

我尝试了下面的例子,但现在使用了正确的信息。

var fruits = [110.111, 1245.22222, 2.458, 0.001];
fruits.sort();
document.write(fruits);

结果:

0.001,110.111,1245.22222,2.458

但我想要像这样的东西

0.001,2.458,110.111,1245.22222

这个代码怎么了?

array.sort([completeFunction]采用一个可选函数,用作自定义比较器

fruits.sort(function(a, b){
  return a - b;
});

如果您想对递减进行排序

fruits.sort(function(a, b){
  return b - a;
});

通过:MDN Array.prototype.sort docs

  • 如果compareFunction(a, b)小于0,则将a排序为比b更低的索引,即a排在第一位
  • 如果compareFunction(a, b)返回0,则使a和b相对于彼此保持不变,但相对于所有不同的元素进行排序。注意:ECMAscript标准并不保证这种行为,因此并非所有浏览器(例如,Mozilla版本至少可以追溯到2003年)都尊重这一点
  • 如果compareFunction(a, b)大于0,则将b排序为比a低的索引
  • 当给定一对特定的元素a和b作为其两个参数时,compareFunction(a, b)必须始终返回相同的值。如果返回不一致的结果,则未定义排序顺序

最近,我一直在做一些函数式编程。我将把这一部分留给那些想以不同方式解决同一问题的人。

首先我们有一些通用的效用函数。当我们想要定义更高阶的ascdesc排序函数时,这些将是必要的。

const sub = x => y => y - x;
const flip = f => x => y => f (y) (x);
const uncurry = f => (x,y) => f (x) (y);
const sort = f => xs => xs.sort(uncurry (f));

现在,您可以根据sub 轻松定义ascdesc

const asc = sort (flip (sub));
const desc = sort (sub);

看看

asc ([4,3,1,2]);  //=> [1,2,3,4]
desc ([4,3,1,2]); //=> [4,3,2,1]

您仍然可以使用sort (comparator) (someData) 进行自定义排序

// sort someData by `name` property in ascending order
sort ((a,b) => a.name - b.name) (someData); //=> ...

您可以使用这样的自定义排序函数:

fruits.sort(function (a,b) {return a - b;});

Array.sort()方法将数字视为字符串,并按ASCII顺序对成员进行排序。

使用自定义函数进行排序

要对其进行排序,您需要创建一个取两个的比较器函数参数,然后用该比较器调用排序函数功能如下:

fruits.sort(function(a,b) { return parseFloat(a) - parseFloat(b) } );

如果要按升序排序,请更改parseInt(a)-parseInt(b)和parseInt(b)-parseInt(a)。注意从a变为b。

您可以定义排序函数:

fruits.sort(function(a,b) {return a>b})