Sobes.tech
Junior
130
questionbank

Каким образом можно удалить все дубликаты из массива?

AI答案

sobes.tech AI

Существует несколько распространенных способов:

  1. Использование 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' }]
    
  2. Использование 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]
    
  3. Использование 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]
    
  4. Использование объекта/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 обычно является самым производительным и читаемым для примитивных типов. Для объектов может потребоваться дополнительная логика.