Назад к вопросам
Middle
6
Задача по JavaScript: написать функцию, которая принимает два массива и возвращает массив из элементов, присутствующих только в одном из массивов (симметрическая разность). Оценить сложность алгоритма.
Компании, где спрашивали
Цифротех
Ответ от нейросети
sobes.tech AI
Вот пример функции на JavaScript, которая возвращает симметрическую разность двух массивов:
function symmetricDifference(arr1, arr2) {
const set1 = new Set(arr1);
const set2 = new Set(arr2);
const result = [];
for (const item of set1) {
if (!set2.has(item)) {
result.push(item);
}
}
for (const item of set2) {
if (!set1.has(item)) {
result.push(item);
}
}
return result;
}
Сложность алгоритма — O(n + m), где n и m — длины входных массивов. Это связано с тем, что операции добавления и проверки в Set выполняются за амортизированное O(1), а мы проходим по каждому элементу обоих массивов один раз.