第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

JS如何根據(jù)另一個數(shù)組的排序?qū)σ粋€數(shù)組進(jìn)行排序

JS如何根據(jù)另一個數(shù)組的排序?qū)σ粋€數(shù)組進(jìn)行排序

狐的傳說 2023-09-21 17:13:57
當(dāng)A被.sorted()時,它變成6,7,8,所以這些數(shù)字得到新的索引值,所以對B做同樣的事情。獲取B內(nèi)部值的當(dāng)前索引,然后根據(jù)A的新排列重新排列它。所以當(dāng)A = 6,7,8時,B將為u,z,hvar arrA = [8, 6, 7] // B follows this arr (A)var arrB = ['h', 'u', 'z'] // B follows AarrA.sort()// output: 6, 7, 8// arrB.followA’s arrangement somehow // output: u, z, harrA.reverse()// output: 8, 7, 6// arrB.follow A’s arrangement// output: h, z, uconsole.log(arrA);console.log(arrB)
查看完整描述

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。)


查看完整回答
反對 回復(fù) 2023-09-21
?
幕布斯7119047

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);


查看完整回答
反對 回復(fù) 2023-09-21
?
長風(fēng)秋雁

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;

      }

    }

}


查看完整回答
反對 回復(fù) 2023-09-21
?
一只萌萌小番薯

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 的值。


如我錯了請糾正我


查看完整回答
反對 回復(fù) 2023-09-21
  • 4 回答
  • 0 關(guān)注
  • 311 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號