arrayIntersect: Difference between revisions
Jump to navigation
Jump to search
Lou Montana (talk | contribs) |
Hypoxic125 (talk | contribs) mNo edit summary |
||
(23 intermediate revisions by 3 users not shown) | |||
Line 6: | Line 6: | ||
|gr1= Arrays | |gr1= Arrays | ||
|descr= Intersects | |descr= Intersects two arrays returning an array of unique common elements, avoiding [[nil]] values. | ||
Using the same array as both parameters will return unique elements of that array. | |||
Intersects only the first dimension of said arrays. | |||
{{Feature|informative|From Arma 3 v 2.14 the order of the intersected elements would follow 'array1' order}} | |||
|s1= array1 [[arrayIntersect]] array2 | |s1= array1 [[arrayIntersect]] array2 | ||
Line 16: | Line 20: | ||
|r1= [[Array]] | |r1= [[Array]] | ||
|x1= < | |x1= <sqf> | ||
_arr1 = [1,2,3,4,5,2,3,4]; | |||
_arr2 = [4,5,6,1,2,3,5,6]; | _arr2 = [4,5,6,1,2,3,5,6]; | ||
[[hint] | hint str (_arr1 arrayIntersect _arr2); // [4,5,1,2,3] | ||
</sqf> | |||
|x2= <sqf> | |||
_arr = [1,2,3,1,2,3,1,2,3,4,5]; | |||
hint str (_arr arrayIntersect _arr); // [1,2,3,4,5] | |||
</sqf> | |||
|x3= Remove [[nil]]s: | |||
<sqf>hint str ([1,2,nil,3] arrayIntersect [1,2,nil,3]); // [1,2,3]</sqf> | |||
|x4= Also works with array elements which are [[isEqualTo|equal]]: | |||
<sqf>hint str ([[1],[2],[3]] arrayIntersect [[2],[3],[4]]); // [[2],[3]]</sqf> | |||
|x5= This command is case-sensitive: | |||
<sqf> | |||
["cAse"] arrayIntersect ["cAse"]; // ["cAse"] | |||
["cAse"] arrayIntersect ["casE"]; // [] | |||
</sqf> | |||
| | |seealso= [[append]] [[set]] [[pushBack]] [[pushBackUnique]] [[apply]] [[select]] [[resize]] [[reverse]] [[count]] [[find]] [[in]] [[forEach]] [[deleteAt]] [[deleteRange]] [[sort]] [[param]] [[params]] [[toArray]] [[toString]] [[splitString]] [[joinString]] [[BIS_fnc_arrayPushStack]] [[BIS_fnc_arrayPush]] | ||
[[ | }} | ||
| | {{Note | ||
|user= Hypoxic125 | |||
|timestamp= 20240526165002 | |||
|text= Selectively filter out elements from _arrayA based on _arrayB. | |||
* Designed to remove the first occurrence of each element found in _arrayB from _arrayA. | |||
* Useful in removing elements where duplicates may exist. | |||
<sqf> | |||
private _arrayA = [1, 2, 3, 2, 4, 5, 4]; | |||
private _arrayB = [2, 2, 4]; | |||
{ | |||
private _index = _arrayA find _x; | |||
if (_index != -1) then | |||
{ | |||
_arrayA deleteAt _index; | |||
}; | |||
} forEach _arrayB; | |||
_arrayA; // is now [1, 3, 5, 4] | |||
</sqf> | |||
}} | }} |
Latest revision as of 19:57, 26 May 2024
Description
- Description:
- Intersects two arrays returning an array of unique common elements, avoiding nil values. Using the same array as both parameters will return unique elements of that array. Intersects only the first dimension of said arrays.
- Groups:
- Arrays
Syntax
- Syntax:
- array1 arrayIntersect array2
- Parameters:
- array1: Array
- array2: Array
- Return Value:
- Array
Examples
- Example 1:
- Example 2:
- Example 3:
- Remove nils:
- Example 4:
- Also works with array elements which are equal:
- Example 5:
- This command is case-sensitive:
["cAse"] arrayIntersect ["cAse"]; // ["cAse"] ["cAse"] arrayIntersect ["casE"]; // []
Additional Information
- See also:
- append set pushBack pushBackUnique apply select resize reverse count find in forEach deleteAt deleteRange sort param params toArray toString splitString joinString BIS_fnc_arrayPushStack BIS_fnc_arrayPush
Notes
-
Report bugs on the Feedback Tracker and/or discuss them on the Arma Discord or on the Forums.
Only post proven facts here! Add Note
- Posted on May 26, 2024 - 16:50 (UTC)
-
Selectively filter out elements from _arrayA based on _arrayB.
- Designed to remove the first occurrence of each element found in _arrayB from _arrayA.
- Useful in removing elements where duplicates may exist.