我致力於聯盟調查。我想根據一個索引與另一個索引是否共享一個數字來對數字對進行分組。所以:JavaScript聯盟對聯盟查找
我有對的陣列,如以下:
pairs: [[1,3], [6,8], [3,8], [2,7]]
什麼對他們在工會組的最佳方式如此:
[ [ 1, 3, 8, 6 ], [ 2, 7 ] ]
([1,3]和[3,8]因爲他們共享而團隊合作3.該團體與[6,8]合併,因爲他們共享8.在javascript中執行此操作的最佳方式是什麼?
以下是其他示例:
pairs: [[8,5], [10,8], [4,18], [20,12], [5,2], [17,2], [13,25],[29,12], [22,2], [17,11]]
into [ [ 8, 5, 10, 2, 17, 22, 11 ],[ 4, 18 ],[ 20, 12, 29 ],[ 13, 25 ] ]
編輯 這裏是我目前使用的方法:
findUnions = function(pairs, unions){
if (!unions){
unions = [pairs[0]];
pairs.shift();
}else{
if(pairs.length){
unions.push(pairs[0])
pairs.shift()
}
}
if (!pairs.length){
return unions
}
unite = true
while (unite && pairs.length){
unite = false
loop1:
for (i in unions){
loop2:
var length = pairs.length;
for (j=0;j<length;j++){
if (unions[i].includes(pairs[j][0])){
if (!unions[i].includes(pairs[j][1])){
unions[i].push(pairs[j][1])
pairs.splice(j, 1)
j-=1;
length-=1
unite = true
}else{
pairs.splice(j, 1)
j-=1
length-=1
}
}else if (unions[i].includes(pairs[j][1])){
unions[i].push(pairs[j][0])
pairs.splice(j, 1)
unite = true
j-=1
length-=1
}
}
}
}
return findUnions(pairs, unions)
}
爲什麼''8''在'6'前面的'[1,3,8,6]'?具體訂單沒有要求嗎? – guest271314
我會稱之爲「派系發現」而不是「工會發現」 –
無訂單要求。 8在6之前,因爲我現在的算法n先增加(3,8),但那不重要 –