4 回答

TA貢獻(xiàn)1883條經(jīng)驗 獲得超3個贊
創(chuàng)建一個二維工作數(shù)組,其元素是來自arrA和的值對arrB:
var work = [];
arrA.forEach(function( v, i ) {
work[ i ] = [ arrA[i], arrB[i] ];
});
現(xiàn)在您可以按任何順序排列,并且來自和 的work值將保持同步:arrAarrB
work.sort(function(x, y) {
return Math.sign( x[0], y[0] );
});
(在上面的示例中,我們按槽 0 中的元素排序,該元素來自arrA。要按 中的元素排序arrB,請將 0 更改為 1。)
現(xiàn)在你可以改變work,例如:
work.reverse();
并提取最初來自 的相應(yīng)元素arrA:
let newAarrA = work.map(function(x) {
return x[0]; // from arrA
});
console.log(newArrA);
(將 0 更改為 1 以獲取相應(yīng)的元素arrB。)

TA貢獻(xiàn)1794條經(jīng)驗 獲得超8個贊
您可以使用“使用映射排序”技術(shù),基本上使用一個臨時數(shù)組,將arrB的元素映射到arrA元素的值,然后對其進(jìn)行排序。
var arrA = [8, 6, 7] // B follows this arr (A)
var arrB = ['h', 'u', 'z'] // B follows A
var tmpMap = arrB.map((el, i) => ({ index: i, value: arrA[i] }));
tmpMap.sort((a, b) => a.value - b.value);
var arrB = tmpMap.map(el => arrB[el.index]);
console.log(arrB);

TA貢獻(xiàn)1757條經(jīng)驗 獲得超7個贊
使用暴力排序例程。交換“ary”中的元素,如果這些元素交換,則交換“bry”中的相同索引。這樣索引交換將相互鏡像。
var ary = [8, 7, 4, 3, 5, 1, 6];
var bry = ['u', 'z', 'y', 'a', 'b', 'f', 'r'];
var i = 0;
var j = 0;
for (i = 0; i < ary.length-1; i++){
for (j = 0; j < ary.length-1; j++){
if (ary[j] > ary[j+1]){
let bigger = ary[j];
ary[j] = ary[j+1];
ary[j+1] = bigger;
// make bry swap the same indexes as ary above
bigger = bry[j];
bry[j] = bry[j+1];
bry[j+1] = bigger;
}
}
}

TA貢獻(xiàn)1795條經(jīng)驗 獲得超7個贊
如果是兩個不同的數(shù)組就不可能了。解決問題的簡單方法是將第二個數(shù)組轉(zhuǎn)換為對象。
let b = {
8: 'H',
6: 'U',
7: 'Z'
}
arrB = arrA.map((val) => return b[val]);
并使用該對象根據(jù)數(shù)組 A 的值獲取數(shù)組 B 的值。
如我錯了請糾正我
添加回答
舉報