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

Создать функцию, которая группирует числа по сумме пар

13.11.2018, 12:58. Показов 1023. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Народ, может кто нибудь помочь как решить данную задачу на js?
У нас есть массив ints.
Необходимо создать функцию, которая группирует числа по сумме пар (sum = 5)
Каждый элемент массива должен использоваться только один раз.
---
test data:
ввод: [22, 3, 5, 0, 2, 2]
вывод: [[3, 2], [5, 0]]

ввод: [-5, 33, 2, 2, 3, 5, 0, 10, 3]
вывод: [[-5, 10], [2, 3], [2, 3], [5, 0]]

ввод: [5, 5, 5, 0, 0, 0, 5]
вывод: [[5, 0], [5, 0], [5, 0]]
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.11.2018, 12:58
Ответы с готовыми решениями:

Clojure Создать функцию которая группирует список в н-элементный подсписоки
В итоге должно получиться вот так: (группируй `(a b c d e f g) 2) ((a b) (c d) (e f) (g))

Создать функцию, которая создаёт структурный объект равный сумме двух векторов
На ввод мы получаем значения х1, х2, у1 и у2. Программа выводит значение получившегося вектора. Прошу оформить с использованием...

Описать функцию, которая возвращает количество пар соседних цифр в записи числа
Описать функцию, которая возвращает количество пар соседних цифр в записи числа типа Longint, удовлетворяющих условию: первая цифра больше...

3
566 / 465 / 183
Регистрация: 14.10.2017
Сообщений: 1,259
13.11.2018, 16:11
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
let sorcArray = [-5, 33, 2, 2, 3, 5, 0, 10, 3];
const getPair = (arr, sum) => {
    let except = [], res = [];
    for(let i = 0; i < arr.length - 1; i++){
        for(let j = i + 1; j < arr.length; j++){
            if(except.includes(j)) continue;
            if(arr[i] + arr[j] == sum){
                    res.push([arr[i],arr[j]]);
                    except.push(i);
                    except.push(j);
            }
        }
    }
    return res;
}
console.log(getPair(sorcArray, 5));
/*
0: (2) [-5, 10]
1: (2) [2, 3]
2: (2) [2, 3]
3: (2) [5, 0]
*/
0
the hardway first
Эксперт JS
 Аватар для j2FunOnly
2475 / 1847 / 910
Регистрация: 05.06.2015
Сообщений: 3,610
13.11.2018, 23:50
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
var pairs = function(arr, sum) {
  arr = arr.slice().sort(function(x, y) {
    return x - y;
  });
 
  var i = 0,
    j = arr.length - 1,
    result = [],
    _sum;
 
  while (i < j) {
    _sum = arr[i] + arr[j];
 
    if (_sum === sum) {
      result.push([arr[i], arr[j]]);
      i += 1;
      j -= 1;
    } else {
      _sum < sum ? i += 1 : j -= 1;
    }
  }
 
  return result;
}
 
console.log(pairs([22, 3, 5, 0, 2, 2], 5)); //=> [[0, 5], [2, 3]]
console.log(pairs([-5, 33, 2, 2, 3, 5, 0, 10, 3], 5)); //=> [[-5, 10], [0, 5], [2, 3], [2, 3]]
console.log(pairs([5, 5, 5, 0, 0, 0, 5], 5)); //=> [[0, 5], [0, 5], [0, 5]]
1
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
14.11.2018, 13:36
PHP/HTML
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
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
</head>
<body>
    <script>
        function pairs(a1, sum) {
            a1 = a1.slice();
            let a2 = [],
                count = a1.length;
            for (let i = 0; i < count - 1; ++i) {
                for (let j = i + 1; j < count; ++j)
                    if (a1[i] + a1[j] === sum) {
                        a2.push([a1[i], a1[j]]);
                        a1.splice(j, 1);
                        --count;
                        break;
                    }
            }
            return a2;
        }
 
        let a1 = [22, 3, 5, 0, 2, 2];
        let a2 = pairs(a1, 5);
        console.log(a2);
 
        a1 = [-5, 33, 2, 2, 3, 5, 0, 10, 3];
        a2 = pairs(a1, 5);
        console.log(a2);
 
        a1 = [5, 5, 5, 0, 0, 0, 5];
        a2 = pairs(a1, 5);
        console.log(a2);
    </script>
</body>
</html>
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.11.2018, 13:36
Помогаю со студенческими работами здесь

Описать функцию, которая возвращает количество пар соседних цифр в записи числа
Описать функцию, которая возвращает количество пар соседних цифр в записи числа типа Longint, удовлетворяющих условию: первая цифра...

Написать функцию, которая возвращает количество пар соседних цифр в записи числа типа Longint, удовлетворяющих условию
Добрый день. Прошу вас помочь с лабой по паскалю, как не пытался - не могу найти решения. Задание: Написать функцию, которая...

Написать функцию, которая для заданого целого числа Х вычисляет количество пар (расположенных друг за другом) нулевых битов в этом числе
Помогите плиз)) Нужно срочно на завтра написать прогу на С++. Если можно с блок-схемой. Заранее спасибо.

Создать функцию которая выводит на экран, числа от 1 до указанного числа
Создать функцию которая выводит на экран, числа от 1 до указанного числа Вот я это написал: #include &lt;iostream&gt; #include...

Создать программу,которая находит минимальное из 3х чисел. Для нахождения минимального числа создать функцию
Создать функцию - double mini (double a, double b, double c), где a,b,c - задание числа. Спасибо за помощь!


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
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-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru