Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   Найти тройные дубликаты в массиве (https://javascript.ru/forum/misc/63029-najjti-trojjnye-dublikaty-v-massive.html)

Blondinka 13.05.2016 12:14

Найти тройные дубликаты в массиве
 
Добрый день.

Нужно найти тройные дубликаты в массиве. Код
function myFunction() {
var arr = [9, 9, 9, 111, 2, 3, 4, 4, 5, 7];
var sorted_arr = arr.slice().sort(); 
var results = [];
for (var i = 0; i < arr.length - 1; i++) {
    if (sorted_arr[i + 1] == sorted_arr[i] == sorted_arr[i+2]) {
        results.push(sorted_arr[i]);
    }
}

alert(results);
}
с тройными не работает.

Этот, тоже, не работает.
function myFunction() {
    var fruits = [3, 3, 3, 5, 4, 6, 8, 9];
    var a = fruits.sort();
    document.getElementById("demo").innerHTML = a;
    for(var i = 0, j = 1, k = 2; i < fruits.length, j < fruits.length, k < fruits.length; i++, j++, k++){
        if(fruits[i].valueOf() == fruits[j].valueOf() == fruits[k].valueOf()){
            alert(fruits[i].valueOf()+" "+fruits[j].valueOf() +" "+fruits[k].valueOf());
        }
    }
}

Dilettante_Pro 13.05.2016 12:58

var arr = [9, 9, 9, 111, 5, 2, 5, 3, 4, 4, 5, 7],
     count = [];

for (var i = 0; i < arr.length; i++) {
      count[arr[i]]= (count[arr[i]] | 0) + 1;
}
count.forEach(function(item, j, array) {
  if (item==3) {
  alert( j );
  }
});

Или дубликаты - когда подряд?

Blondinka 13.05.2016 13:13

Dilettante_Pro,
Спасибо. Для облегчения поиска дубликатов, делала сортировку.

destus 13.05.2016 13:52

Вариант.
<script src="http://underscorejs.ru/underscore-min.js"></script>
<script>
    _.chain([9, 9, 9, 111, 5, 2, 5, 3, 4, 4, 5, 7])
            .countBy()
            .each( (val, key) => (val === 3) && (alert(key)))
</script>

рони 13.05.2016 14:49

без повтора и двойные, тройные, четверные ... в массиве
 
:)
<script>
var arr = [9, 9, 9, 111, 5, 2, 5, 3, 4, 4, 5, 7];
function foo(a, c) {
    c--;
    var d = {};
    return a.filter(function(b, e, a) {
        if (d[b]) return !1;
        d[b] = !0;
        for (var f = 0; ~(e = a.indexOf(b, ++e));) f++;
        return f == c
    })
};

document.write(JSON.stringify(foo(arr,1)) + "<br>")//без повтора
document.write(JSON.stringify(foo(arr,3)))// тройные дубликаты

  </script>

destus 13.05.2016 14:53

рони,
Реальность такова, что мой вариант быстрее и красивее :D

Blondinka 13.05.2016 15:09

destus, да, но там нужно грузить библиотеку. А у меня вся программа на чистом JS.

рони 13.05.2016 15:15

Dilettante_Pro,
опухнет же массив count :-?
destus,
может и быстрее , но грузить библиотеку предварительно и конвертировать полученный результат.

destus 13.05.2016 15:18

Цитата:

А у меня вся программа на чистом JS.
Что насчет кросс-браузерности? Или вы свой фрэймворк разрабатываете?
Цитата:

но грузить библиотеку предварительно
15кб...
Underscore - вне закона и должна быть на каждом большом проекте :)

Blondinka 13.05.2016 15:23

Кто-нибудь знает, почему мой код не работает?

рони 13.05.2016 15:28

Blondinka,
Цитата:

Сообщение от Blondinka
if (sorted_arr[i + 1] == sorted_arr[i] == sorted_arr[i+2])

так не бывает в js

Blondinka 13.05.2016 15:30

destus,
Писала на jQuery.
1. Столкнулась с тем, что не могу ничего написать без него.
2. Писала свой "большой проект" на jQuery и в один прекрасный день, он не запустился. Использовала CDN. Наверно, они там что-то обновили. Было очень обидно.
3. Часто встречаю выражение "джейквэримонки". Наверно, jQuery - зло. Подобное 1 раз встречала, по отношению к React.
Пришла к выводу, что не стоит привыкать к библиотекам.

Blondinka 13.05.2016 15:31

рони,
почему?

рони 13.05.2016 15:33

Blondinka, код будет верным если более 3 повторов в массиве нет, типа 1,1,1,1 иначе нужно менять алгоритм или использовать вариант предложенный выше
function myFunction() {
var arr = [9, 9, 9, 111, 5, 2, 5, 3, 4, 4, 5, 7];
var sorted_arr = arr.slice().sort(function(a,b) {
   return b - a
});
var results = [];
for (var i = 0; i < arr.length - 2; i++) {
    if (sorted_arr[i + 1] == sorted_arr[i] && sorted_arr[i] == sorted_arr[i+2]) {
        results.push(sorted_arr[i]);
    }
}

alert(results);
}
myFunction()

destus 13.05.2016 16:56

Цитата:

Сообщение от Blondinka (Сообщение 416439)
destus,
Писала на jQuery.
1. Столкнулась с тем, что не могу ничего написать без него.
2. Писала свой "большой проект" на jQuery и в один прекрасный день, он не запустился. Использовала CDN. Наверно, они там что-то обновили. Было очень обидно.
3. Часто встречаю выражение "джейквэримонки". Наверно, jQuery - зло. Подобное 1 раз встречала, по отношению к React.
Пришла к выводу, что не стоит привыкать к библиотекам.

В больших проектах вроде все уже юзают менеджеры пакетов Bower/npm и хранят зависимости проекта от сторонних библиотек в одном файле.

Blondinka 13.05.2016 18:48

destus, откуда мне это было знать? Но тогда это был мой большой пет-проект. Сейчас я уже знаю, о существовании Bower/npm но не понимаю, как этим пользоваться.

Vlasenko Fedor 13.05.2016 18:57

var arr = [9, 9, 9, 111, 5, 2, 5, 3, 4, 4, 5, 7];
var res = arr.filter(function(value, index){
    return index != arr.indexOf(value) && index != arr.lastIndexOf(value);
});

alert(res);

Blondinka 13.05.2016 19:43

А что, если я хочу получить последовательность. Скажем, [2, 3, 4] ?

рони 13.05.2016 19:49

Цитата:

Сообщение от Blondinka
А что, если я хочу получить последовательность. Скажем, [2, 3, 4] ?

можно пример исходного массива и результат?

Blondinka 13.05.2016 19:58

рони,
тот же массив [9, 9, 9, 111, 5, 2, 5, 3, 4, 4, 5, 7] - > sort()
Результат - первая последовательность из трёх чисел - [2, 3, 4]

рони 13.05.2016 20:18

Blondinka,
не понял ничего.

Blondinka 13.05.2016 20:26

рони,
var arr = [1, 2, 3, 4, 5];
for (var i = 0; i < arr.length; i++) {
      /*Magic*/
}
alert(result); //1,2,3 ||2,3,4 || 3,4,5

Результат - первая последовательность из трёх чисел.

рони 13.05.2016 20:30

Blondinka,
нашли и что в результате true или false? или как

Vlasenko Fedor 13.05.2016 20:31

Цитата:

Сообщение от Blondinka
тот же массив [9, 9, 9, 111, 5, 2, 5, 3, 4, 4, 5, 7] - > sort()
Результат - первая последовательность из трёх чисел - [2, 3, 4]

var arr = [9, 9, 9, 111, 5, 2, 5, 3, 4, 4, 5, 7];
var res = arr.sort(function(a, b){return a > b ? 1: a==b ? 0: -1}).slice(0, 3);
alert(res);

Blondinka 13.05.2016 20:36

рони,
в результате массив чисел.

Blondinka 13.05.2016 20:43

Poznakomlus,
почти. Разница между числами должна быть 1.
Например, из массива [1, 2, 4, 5, 6] результат будет [4,5,6], т.к. разница между этими числами == 1.

рони 13.05.2016 20:46

Цитата:

Сообщение от Blondinka
Poznakomlus,
почти. Разница между числами должна быть 1.

подожду переводчика, чую пагинатор нужен

рони 13.05.2016 20:51

Blondinka,
а как вы разницу считаите?

Blondinka 13.05.2016 20:54

рони,
Другими словами: у меня есть таблица. У каждой ячейки - числовой id. Мне нужно получить 3 пустых ячейки, которые идут подряд. Пользователь не заполнил 3 ячейки подряд? Отправить в ад!:p

рони 13.05.2016 20:59

Blondinka,
то есть это массив незаполненных ячеек ? тогда почему id повторяются

Blondinka 13.05.2016 21:07

рони,
да, но только тех, что идут подряд. 3 необязательное число (но не меньше трёх). Может быть и 5. Гдавное, чтоб они шли подряд. Пример: 8, 9, 10, 11.

рони 13.05.2016 21:18

Blondinka,
вариант для 3
<script>
var arr = [9, 9, 9, 111, 5, 2, 5, 3, 4, 4, 5, 7] ;

function test(a) {
    a = a.slice().sort(function(a, b) {
        return a - b
    });
    return a.some(function(c, b) {
        var d = a[b + 1],
            e = a[b + 2];
        return c == d - 1 && c == e - 2 && (a = [c, d, e])
    }) && a
};
document.write(JSON.stringify(test(arr)))
  </script>

Blondinka 13.05.2016 21:26

Цитата:

Сообщение от рони
то есть это массив незаполненных ячеек ? тогда почему id повторяются

Хотела сама написать. Решила, что если найду функцию поиска дубликатов - будет роще написать то, что мне нужно. Пол-дня пыталась написать/переделать чужое. Безрезультатно. Без этой функции программа работать не будет.

Blondinka 13.05.2016 21:31

рони,
спасибо. Работает.

рони 13.05.2016 21:35

Blondinka,
почему дубликаты есть? id уникально

Blondinka 13.05.2016 21:45

рони,
потому что я хотела усложнить себе задачу и написать хоть что-нибудь сама (переделать программу с "поиска дубликатов" на "поиск последовательностей"). Я знаю, что id уникально. В основном коде, оно добавляется только 1 раз.

рони 13.05.2016 21:55

Blondinka,
функция для последовательности любой длины больше 2, вернёт найденную первую последовательность или false.
<script>
var a = [20,21,22,1,2,3,4,5,8] ;

function test(a) {
    a = a.slice().sort(function(a, b) {
        return a - b
    });
    return a.some(function(d, b) {
        var c = a.slice(b);
        c.some(function(a, b) {
            return a != c[b + 1] - 1 && (c = c.slice(0, b + 1))
        });
        return 2 < c.length && (a = c)
    }) && a
};
document.write(JSON.stringify(test(a)))
  </script>

Blondinka 13.05.2016 22:10

рони, спасибо.


Часовой пояс GMT +3, время: 00:21.