curriculum/challenges/english/blocks/daily-coding-challenges-javascript/691f7773cddba1caf1bf5ecb.md
Given an array of values, remove all occurrences of the most frequently occurring element and return the resulting array.
purgeMostFrequent([1, 2, 2, 3]) should return [1, 3].
assert.deepEqual(purgeMostFrequent([1, 2, 2, 3]), [1, 3]);
purgeMostFrequent(["a", "b", "d", "b", "c", "d", "c", "d", "c", "d"]) should return ["a", "b", "b", "c", "c", "c"].
assert.deepEqual(purgeMostFrequent(["a", "b", "d", "b", "c", "d", "c", "d", "c", "d"]), ["a", "b", "b", "c", "c", "c"]);
purgeMostFrequent(["red", "blue", "green", "red", "blue", "green", "blue"]) should return ["red", "green", "red", "green"].
assert.deepEqual(purgeMostFrequent(["red", "blue", "green", "red", "blue", "green", "blue"]), ["red", "green", "red", "green"]);
purgeMostFrequent([5, 5, 5, 5]) should return [].
assert.deepEqual(purgeMostFrequent([5, 5, 5, 5]), []);
purgeMostFrequent([10, 12, 7, 3, 7, 7, 12, 12]) should return [10, 3].
assert.deepEqual(purgeMostFrequent([10, 12, 7, 3, 7, 7, 12, 12]), [10, 3]);
function purgeMostFrequent(arr) {
return arr;
}
function purgeMostFrequent(arr) {
const freq = {};
for (const val of arr) {
freq[val] = (freq[val] || 0) + 1;
}
const maxFreq = Math.max(...Object.values(freq));
const toRemove = new Set(
Object.keys(freq).filter(key => freq[key] === maxFreq)
);
return arr.filter(val => !toRemove.has(String(val)));
}