为了账号安全,请及时绑定邮箱和手机立即绑定

我想对数组的元素进行排序[关闭]

我想对数组的元素进行排序[关闭]

哔哔one 2019-04-10 14:15:04
假设我有如下数组var array=[3,4,5,5,5,6,8,3,12,1,1,1];然后结果应该是array=[5,1,3,4,6,8,12];JavaScript或nodejs中必需的实现
查看完整描述

4 回答

?
摇曳的蔷薇

TA贡献1793条经验 获得超6个赞

我在这个jsbin示例中使用了lodash和普通JavaScript数组方法的组合:

var arr = [3,4,5,5,5,6,8,3,12,1,1,1];var sorted = _.sortBy(_.toPairs(arr.reduce(function(agg, curr) {
  agg[curr] = agg[curr] ? agg[curr] + 1 : 1;

  return agg;}, {})), function(pair) {
  return -pair[1];}).map(function(pair) {
  return pair[0];});console.log(sorted); // => ["1", "5", "3", "4", "6", "8", "12"]

但是,排序顺序"5"和顺序"1"不同3,4,6,8,12,因为没有为具有相同计数的数字指定排序顺序。

上面所做的是创建number=>count(例如{ "1": 3, "5": 3 })的映射,然后将它们配对为元组(因为对象不能在JavaScript中确定性地排序:) [["1", 3], ["5", 3]]。然后,我们简单地根据计数对元组集合进行排序,并映射元组集合以仅返回数字(例如["1", "5", /* etc. */ ])。


查看完整回答
反对 回复 2019-05-08
?
肥皂起泡泡

TA贡献1829条经验 获得超6个赞

var array = [3, 4, 5, 5, 5, 6, 8, 3, 12, 1, 1, 1];var obj = {};array.forEach(e => obj[e] = obj[e] + 1 || 1);var sorted = Object.keys(obj)
    .map(e => ({ n: e, times: obj[e] }))
    .sort((a, b) => b.times - a.times)
    .map(e => e.n);document.write(sorted);


查看完整回答
反对 回复 2019-05-08
?
largeQ

TA贡献2039条经验 获得超7个赞

function sortArray(array) { 


    var reducedArray = array.filter(function(item, pos) { //A copy without duplicates

       return array.indexOf(item) == pos;

    })


    var elementFreq = {} //Object that contains element frequencies

    for (var i=0; i<reducedArray.length; i++) {

        var count = 0;

        for (var j=0; j<array.length; j++) {

            if (array[j] == reducedArray[i]) {

                count++;

            }

        }

        elementFreq[array[i]] = count;

    }


    function compare(a,b) { //compares the frequency of two elements

        return elementFreq[b]-elementFreq[a]

    }


    reducedArray.sort(compare) //sorts reducedArray based using compare function


    return reducedArray 

}


查看完整回答
反对 回复 2019-05-08
  • 4 回答
  • 0 关注
  • 681 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信