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. */ ]
)。
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);
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
}
添加回答
举报