456 читали · 1 год назад
Java 415. Как найти повторяющиеся элементы в массиве?
Для поиска повторяющихся элементов в массиве можно использовать различные подходы. Рассмотрим два простых способа. int[] arr = {1, 2, 3, 4, 5, 2, 3}; for (int i = 0; i < arr.length; i++) { for (int j = i + 1; j < arr.length; j++) { if (arr[i] == arr[j]) { System.out.println("Повторяющийся элемент: " + arr[i]); } } } В данном примере мы используем два вложенных цикла for, чтобы перебрать все пары элементов массива и сравнить их между собой. Если находим два одинаковых элемента, то выводим сообщение о том, что найден повторяющийся элемент...
5 лет назад
Сортировка и подсчет одинаковых элементов массива
Тут возникла задача автоматически посчитать одинаковые элементы массива. Сначала думал сортировать и сравнивать в цикле, но нашлось куда как более элегантное решение. var meArray = ["el1", "el2", ...]; var counts = meArray.reduce((map, val) => {map[val] = (map[val] || 0)+1; return map}, {} ); console.log (counts) При чём, там есть и более читаемое решение: var counts = {}; meArray.forEach(function(x) {counts[x] = (counts[x] || 0)+1; }); Но в одну строку ещё круче 🍉 Тут сразу возникает вопрос: как работает...