J'ai un tableau d'objets et un tableau normal, et si un élément du tableau d'objets est égal à un élément du tableau normal, je souhaite le supprimer. C'est déroutant pour moi.
Voici ce que j'ai essayé jusqu'à présent :
var pays = [ {ChoicesID : 1, ChoicesName : 'afghanistan'}, {ChoicesID : 2, ChoicesName : 'albanie'}, {ChoicesID : 3, ChoicesName : 'Algérie'}, {ChoicesID : 4, ChoicesName : 'angola'}, {ChoicesID : 5, ChoicesName : 'argentine'}, {ChoicesID : 6, ChoicesName : 'Arménie'} ]; var réponse = ['afghanistan','albanie','algérie']; var ChoicesName = new Set(countries.map(d => d.ChoicesName)); var NewCountries = [...ChoicesName, ...answer.filter(d => !ChoicesName.has(countries.find(o => o.ChoicesName === réponse)))]; console.log(NouveauxPays);
Le résultat attendu devrait ressembler à ceci :
var NewCountries = [ {ChoicesID : 4, ChoicesName : 'angola'}, {ChoicesID : 5, ChoicesName : 'argentine'}, {ChoicesID : 6, ChoicesName : 'Arménie'} ];
Vous aimez ça ?
Utilisez
filter
并删除如果answer
中存在它。创建一个answerSet
以进行 O(1) 的查找,否则可以使用includes
,但includes
的时间复杂度为 O(m)(其中 m 是answer
数组中的元素数量,n 是countries
le nombre d'éléments dans le tableau)Utiliser l'ensemble
O(m) + O(n).O(1) = O(n) (étant donné n>m)
L'utilisation comprend
O(n).O(m) = O(nm)