2 回答
TA贡献1831条经验 获得超9个赞
你这个题目有点问题吧,你对一个对象的键排序有啥意义,键值对的访问时间复杂度就是O(1)的,你如果是数组的话我可以理解。
var a = {1: [4, 7], 2: [2, 6], 3: [4, 9], 4: [1, 8], 5: [5, 5]}
var array = []
var result = {}
var i = 0
Object.keys(a).forEach(function(key){
array.push({
key: key,
value: a[key]
})
})
console.log(array)
array = array.sort(function(a,b) {
if (a.value[0] === b.value[0]) {
return a.value[1] - b.value[1]
}
return a.value[0] - b.value[0]
})
console.log(array)
for (var i = 0; i < array.length; i++) {
result[array[i].key] = array[i].value
}
console.log(a)
console.log(result)
TA贡献1864条经验 获得超2个赞
let a = { 1: [4, 7], 2: [2, 6], 3: [4, 9], 4: [1, 8], 5: [5, 5] };
let arr = [];
Object.getOwnPropertyNames(a).forEach((attr, index) => {
let obj = {};
obj[attr] = JSON.parse(JSON.stringify(a[attr]));
arr.push(obj);
});
// 上面为改变数据结构,对象转数组;
function compare(a, b) {
let valueA = a[Object.keys(a)[0]],
valueB = b[Object.keys(b)[0]];
if (valueA[0] < valueB[0]) {
return -1;
} else if (valueA[0] > valueB[0]) {
return 1;
} else {
return valueA[1] < valueB[1] ? -1 : 1;
}
}
console.log(arr.sort(compare));
这个数据结构有问题,上面代码的1/3就是用来改数据结构的,一般数据结构会是这样子:
如果不确定第一个键是否是数字的话:
[ { '1': [ 4, 7 ] },
{ '2': [ 2, 6 ] },
{ '3': [ 4, 9 ] },
{ '4': [ 1, 8 ] },
{ '5': [ 5, 5 ] } ]
如果第一个键肯定是数字:
[ [ 4, 7 ]
[ 2, 6 ]
[ 4, 9 ]
[ 1, 8 ]
[ 5, 5 ] ]
添加回答
举报