Compare 2 arrays and show unmatched elements from array 1 [duplicate]

我的未来我决定 提交于 2020-04-07 21:11:35

问题


I have 2 arrays as follows. I want to compare both arrays and only provide the elements from 'check' which are not present in 'data' array.

var check= ["044", "451"],
data = ["343", "333", "044", "123", "444", "555"];

The function used is as follows. This function will result in providing the elements in 'check' array which are present in 'data' array

function getMatch(a, b) {
var matches = [];

for ( var i = 0; i < a.length; i++ ) {
    for ( var e = 0; e < b.length; e++ ) {
        if ( a[i] === b[e] ) matches.push( a[i] );
    }
}
return matches;
}

getMatch(check, data); // ["044"] ---> this will be the answer as '044' is only present in 'data'

I want to have a list of elements which are not present in 'data' array. Can someone let me know how to achieve this.


回答1:


You could use filter and Set, providing the Set as context to the filter method, so it can be accessed as this:

var check= ["044", "451"],
data = ["343", "333", "044", "123", "444", "555"];

var res = check.filter( function(n) { return !this.has(n) }, new Set(data) );

console.log(res);

Note that this runs in O(n) time, contrary to indexOf/includes based solutions, which really represent a nested loop.




回答2:


There is a lot of ways to achieve this, however I will keep your style of coding. Before nested loop set matches flag to false and set it to true in nested loop if match found, after nested loop check your flag if it is false then push element in missing array.

function getMissing(a, b) {
    var missings = [];
    var matches = false;

    for ( var i = 0; i < a.length; i++ ) {
        matches = false;
        for ( var e = 0; e < b.length; e++ ) {
            if ( a[i] === b[e] ) matches = true;
        }
        if(!matches) missings.push( a[i] );
    }
    return missings;
}



回答3:


You can use indexOf and filter for this:

check.filter((item) => { 
  return data.indexOf(item) === -1 
})



回答4:


Edit

The .find() method, as mentioned in a comment, only returns a single value satisfying the predicate function it is given. To correct this, simply substitute .find() with the .filter() function and it should work as intended. Thanks for the catch.

If you're familiar with ES6, you can use the purpose-built .find() Array method; it is, afterall, provided for situations just like the one described. It takes a predicate function and returns the values from the array .find() was called on (here, check) that satisfy the predicate function argument. In my code, the predicate function simply checks for values that are not present in the data array. .includes() is likewise a product of the recent ES6 JavaScript specification and returns a Boolean.

var check= ["044", "451"],
data = ["343", "333", "044", "123", "444", "555"];

let notPresentInData = check.filter(val => !data.includes(val));
console.log(notPresentInData);


来源:https://stackoverflow.com/questions/40537972/compare-2-arrays-and-show-unmatched-elements-from-array-1

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!