Алгоритмы: Поиск дублей в массиве

Выполнение задачи будет на JavaScript в нескольких вариантах с примерной оценкой Big O Notation. Искомые дубли являются только примитивами.

Самое базовое решение, это 2 цикла

Самое простое решение «в лоб», если линейно пытаться решить. Нужно обязательно собрать где-то значения, в этом случае объект, чтобы сосчитать и потом получить их. Сложность алгоритма ~ O(n2)

function findDuplicates(arr) {
	const valueKeyCounters = {};
	for (let i = 0; i < arr.length; i++) {
		if (valueKeyCounters[arr[i]]) {
			continue;
		}

		for (let j = i; j < arr.length; j++) {
			if (valueKeyCounters[arr[j]]) {
			valueKeyCounters[arr[j]] = valueKeyCounters[arr[j]] + 1;
			} else {
			valueKeyCounters[arr[j]] = 1;
			}
		}
	}

	const resultArr = [];
	for (key in valueKeyCounters) {
		if (valueKeyCounters[key] > 1) {
			resultArr.push(key)
		}
	}

	return resultArr
;
}

const collection = [1, 2, 2, 3, 4, 5, 5];

Самый короткий вариант через filter и IndexOf:

Сложность алгоритма ~ O(n2)

const collection = [1, 2, 2, 3, 4, 5, 5];
const findDuplicates = arr => 
   arr.filter((item, index) => arr.indexOf(item) !== index)
console.log(findDuplicates(collection)); // результат: [2, 5]

Решение через коллекцию значений Set:

Сложность алгоритма ~ O(n)

function findDuplicates(arr) {
    const uniqueElements = new Set(arr);
    const filteredElements = arr.filter(item => {
        if (uniqueElements.has(item)) {
            uniqueElements.delete(item);
        } else {
            return item;
        }
    });

    return [...new Set(filteredElements)]
}

const collection = [1, 2, 2, 3, 4, 5, 5];
console.log(findDuplicates(collection)); // Результат: [2, 5]

Интересное решение через рекурсию:

Сложность алгоритма ~ O(n). У решения есть минус т.к мутируется сама коллекция.

const findDuplicates = (arr, double = [], len = 0, deletable = false) => {
   if(len < arr.length){
      if (deletable) {
         double.push(arr[len]);
         arr.splice(len, 1);
         len--;
      }
      return findDuplicates(arr, double, len+1, arr[len] === arr[len+1])
   };
   return double;
};

const collection = [1, 2, 2, 3, 4, 5, 5];
console.log(findDuplicates(collection)); // Результат: [2, 5]
Читайте также
Игра «Нейрогород» на знание JavaScript и исправление фронтендерских багов
Игра «Нейрогород» на знание JavaScript и исправление фронтендерских багов
Игра «Нейрогород» на знание JavaScript и исправление фронтендерских багов

Задача игры — устранить все баги, особенно присматриваться к любым странным и необычным явлениям во внешнем облике города.

Apple Vision Pro: какие приложения не будут работать
Apple Vision Pro: какие приложения не будут работать
Apple Vision Pro: какие приложения не будут работать

Очки дополненной реальности могут внести новый опыт для веб-разработки и приложений. Какие приложения уже работаю с Vision Pro.

В TypeScript 5.3 добавили ​​поддержку атрибутов импорта
В TypeScript 5.3 добавили ​​поддержку атрибутов импорта
В TypeScript 5.3 добавили ​​поддержку атрибутов импорта

TS теперь включает одну опцию для определенного редактора, прежде он добавлял модификатор типа, полагаясь на настройки разработчика

Ретроспектива CSS 2023, что было нового?
Ретроспектива CSS 2023, что было нового?
Ретроспектива CSS 2023, что было нового?

Новинки в 2023 CSS