Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
0 / 0 / 0
Регистрация: 04.01.2017
Сообщений: 1

Не уникальные элементы

04.01.2017, 20:46. Показов 2260. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день! Есть не пустой массив элементов. Нужно написать функцию,которая возвращает тот же массив без уникальных элементов.Вот что мне удалось изобрести:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
var arr = ([.......]),
    len = arr.length;
    
function nonUnique(arr) {
    "use strict";
    var result = [];
    console.log(arr);
    console.log("len=", len);
    for (var i = 0;i < len; i++) {
        for (var j = 0; j < len; j++) {
            if (i!=j && arr[i] == arr[j]) {
                result.push(arr[i]);
            }
        }
    }
    console.log(result);
}
Но проблема в том что когда в массиве под ряд стоит много одинаковых элементов,функция их дублирует. Подскажите,как избежать этого. Спасибо.

Добавлено через 3 часа 37 минут
Сделал по другому. Может кому-то понадобится:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
var arr = ([.........]),
    len = arr.length,
    nonun = [];
 
Array.prototype.in_array = function (p_val) {
    "use strict";
    for (var i = 0, l = this.length; i < l; i++)  {
        if(this[i] == p_val) {
            return true;
        }
    }
    return false;
}
 
    
function nonUnique(arr) {
    "use strict";
    var result = [];
    for (var i = 0;i < len; i++) {
        var f = 1;
        for (var j = 0; j < len; j++) {
            if (i!=j && arr[i] == arr[j]) {
                f = 0;
                break;
            }
        }
        if (f==1) {
            result.push(arr[i]);
        }
        
    }
    for (var i = 0;i < len; i++) {
        if (result.in_array(arr[i]) ==false) {
        nonun.push(arr[i]);
    }
    }
    console.log(nonun);
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.01.2017, 20:46
Ответы с готовыми решениями:

Не добавляются уникальные элементы в массив
Пишу свой велосипед по удалению одинаковых элементов массива. Как бы при выводе в консоль дубли не попадаются т.е выводится всё как нужно...

Найти в массиве повторяющиеся элементы и записать только уникальные элементы в новый массив из первого массива
Всем привет. Можете помочь написать такой алгоритм, нужно в одном массиве найти повторяющиеся элементы, а затем вставить в другой массив...

Уникальные элементы списка
Есть два List&lt;string&gt;. Каким образом найти все элементы первого списка, которых нет во втором?

2
супермизантроп
Эксперт JS
3941 / 2979 / 692
Регистрация: 18.04.2012
Сообщений: 8,629
05.01.2017, 09:49
Цитата Сообщение от Rachini Посмотреть сообщение
Может кому-то понадобится
это вряд ли -- слишком специфичная у вас задача
обычно требуется из массива удалить дубликаты (т.е. повторяющиеся элементы), оставив уникальные (присутствующие единожды)... например, насобирали ссылок по интересующему кейворду в разных поисковиках, надо составить список уникальных ссылок
у вас же всё как раз наоборот -- даже затрудняюсь придумать реальное применение вашей задаче
0
 Аватар для Noiro
6 / 6 / 6
Регистрация: 16.03.2016
Сообщений: 38
06.01.2017, 18:05
Ну как-то так работает на скорую руку:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
'use strict'
 
var values = [5, 10, 12, 3, 1, 10, 5, 3]
var woUniq = deleteUniq(values);
alert(woUniq); //5, 10, 3, 10, 5, 3
 
function deleteUniq(arr){
    var result = [];
    var tmpRes = [];
    var tmpArr = arr.concat();
 
    //check, is we have any mach.in (if we have, return true)
    function isMach(item){
        return (item == currentValue);
    }
 
    //create new arr with list of not uniq values
    for(var i = 0; i != tmpArr.length;){
        var currentValue = tmpArr.shift();
        //is tmpArr have other currentValue?
        if (tmpArr.some(isMach)){
        //if it have, save currentValue in tmpRes[]
            tmpRes.push(currentValue);
        }else continue;
    }
 
    //create result with uniq values only from original arr
    for (var i = 0; i < arr.length; i++){
        var currentValue = arr[i];
        //is we have this value in list of not uniq values?
        if(tmpRes.some(isMach)){
            result.push(currentValue);
        }else continue;
    }
    return result;
}
Сразу отмечу - работает под 'use strict', будет ли в старом - хз. Но у вас вроде бы тоже использовался.

И 100% даю что код можно минимум в два раза сократить, это на скорую руку.

Добавлено через 1 минуту
О... Вы уже сделали)) . Не заметил.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.01.2017, 18:05
Помогаю со студенческими работами здесь

Выделить уникальные элементы
Добрый день. Есть массив с периодами отсутствия сотрудника = на скрине. как оставить только уникальные периоды из arr_Kab? ...

Уникальные элементы матрицы
Дана матрица найти уникальные элементы матрицы и их количество. Уникальным считается если от этого элемента справа стоят все элементы...

Уникальные элементы в массиве
Функция должна проверить,есть ли повторяющиеся элементы в массиве. Если нет-возвратить единицу, иначе - 0 И сделать это при помощи...

Удалить уникальные элементы из списка
Всем привет! class Program { static void Main(string args) { var foos = new List&lt;Foo&gt;(); ...

Вывести уникальные элементы массива
Кто поможет решить на c++ такую задачу. В массиве имеются различные элементы (пример: a={1,6,2,3,3,4,2,5,1}) нужно вывести разные(не...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru