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

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

04.01.2017, 20:46. Показов 2250. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Ниже машинный перевод статьи The Thinkpad X220 Tablet is the best budget school laptop period . Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы,. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru