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 ] ]
添加回答
舉報