forked from CodeToExpress/dailycodebase
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsol2b_frequencycount.js
More file actions
32 lines (25 loc) · 877 Bytes
/
sol2b_frequencycount.js
File metadata and controls
32 lines (25 loc) · 877 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
/**
* @author MadhavBahlMD
* @date 18/01/2019
* Method - Frequency Count (object)
*/
function searchCommonElements (arr1, arr2, arr3) {
let commonElements = [];
// Create frequency count
let freq1 = {},
freq2 = {},
freq3 = {};
assignFrequency (freq1, arr1);
assignFrequency (freq2, arr2);
assignFrequency (freq3, arr3);
for (let key in freq1)
if (key in freq2 && key in freq3)
commonElements.push (parseInt(key));
return commonElements;
}
function assignFrequency (freq, arr) {
for (let element of arr)
freq[element] = (freq[element] || 0) + 1;
}
console.log (searchCommonElements ([1, 4, 6, 2, 3, 7, 8, 9], [2, 5, 4, 6, 8, 1], [1, 2, 3, 4])); // [1, 2, 4]
console.log (searchCommonElements ([1, 2, 4, 6, 7, 9, 11, 14, 15], [2, 3, 4, 5, 6, 7, 8, 9], [2, 4, 6, 8])); // [2, 4, 6]