Junior
129
questionbank
Каким образом можно удалить все дубликаты из массива?
Ответ от нейросети
sobes.tech AI
Существует несколько распространенных способов:
-
Использование
Set: Наиболее современный и лаконичный способ.Setхранит только уникальные значения.const arr = [1, 2, 2, 3, 4, 4, 5]; const uniqueArr = [...new Set(arr)]; // uniqueArr будет [1, 2, 3, 4, 5]const arr = [{ id: 1, name: 'A' }, { id: 2, name: 'B' }, { id: 1, name: 'A' }]; const uniqueArr = Array.from(new Set(arr.map(JSON.stringify))).map(JSON.parse); // Для объектов нужно преобразовать их в строки для корректного сравнения Set // uniqueArr будет [{ id: 1, name: 'A' }, { id: 2, name: 'B' }] -
Использование
filterиindexOf: Фильтрация массива, оставляя элементы, у которых первое вхождение равно текущему индексу.const arr = [1, 2, 2, 3, 4, 4, 5]; const uniqueArr = arr.filter((item, index) => arr.indexOf(item) === index); // uniqueArr будет [1, 2, 3, 4, 5] -
Использование
reduce: Создание нового массива, добавляя элементы, если их еще нет в аккумуляторе.const arr = [1, 2, 2, 3, 4, 4, 5]; const uniqueArr = arr.reduce((accumulator, current) => { if (!accumulator.includes(current)) { accumulator.push(current); } return accumulator; }, []); // uniqueArr будет [1, 2, 3, 4, 5]const arr = [1, 2, 2, 3, 4, 4, 5]; const uniqueArr = arr.reduce((accumulator, current) => accumulator.includes(current) ? accumulator : [...accumulator, current], []); // Более короткий вариант // uniqueArr будет [1, 2, 3, 4, 5] -
Использование объекта/Map: Создание временного объекта или
Mapдля отслеживания уже встреченных элементов.const arr = [1, 2, 2, 3, 4, 4, 5]; const seen = {}; const uniqueArr = arr.filter(item => seen.hasOwnProperty(item) ? false : (seen[item] = true)); // uniqueArr будет [1, 2, 3, 4, 5]const arr = [1, 2, 2, 3, 4, 4, 5]; const seen = new Map(); const uniqueArr = arr.filter(item => { if (!seen.has(item)) { seen.set(item, true); return true; } return false; }); // uniqueArr будет [1, 2, 3, 4, 5]
Метод с использованием Set обычно является самым производительным и читаемым для примитивных типов. Для объектов может потребоваться дополнительная логика.