Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/21: Рейтинг темы: голосов - 21, средняя оценка - 5.00
 Аватар для Helen_2001
15 / 13 / 4
Регистрация: 23.08.2017
Сообщений: 187

Перебор всех комбинаций

11.10.2021, 19:03. Показов 4777. Ответов 17
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем приветики.
Помогите решить задачку, а то сойду с ума
Суть задачки. Есть массив в виде map. То, что в first не важно, а вот second очень важно.
Нужно перебрать все комбинации при учете, что длина вектора внимание, разная.
В данном примере массивы

[1,2,3,4]
[1,2]
[1,2,3]


Нужно чтобы получилась длина значений как arr.size() при этом перебрать все комбинации из arr.second

1 1 1
2 1 1
3 1 1
4 1 1
1 2 1
1 2 2
1 2 3


и так далее, последовательность перебора не важна, важно чтобы все они были уникальные по максимуму.

C++
1
2
3
4
5
  std::map<std::string, std::vector<int32_t>> arr;
 
  arr.emplace("a",std::vector<int32_t>({1,2,3,4}));
  arr.emplace("b",std::vector<int32_t>({1,2}));
  arr.emplace("c",std::vector<int32_t>({1,2,3}));
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.10.2021, 19:03
Ответы с готовыми решениями:

Перебор всех комбинаций
Здравствуйте, подскажите как переделать этот код, что бы он начинал с нужной длины строки? #include &lt;vector&gt; std::string...

Быстрый перебор всех комбинаций 32 байтов
Здравствуйте, как можно очень быстро перебрать все комбинации 32 байтов, с записью результата в string для сравнения строк ? то-есть...

Перебор комбинаций
Доброго времени суток. Нашел в сети картинку - генератор речей. 4 столбика по 6 фраз в каждом. При переборе слева направо получается...

17
Модератор
Эксперт С++
 Аватар для zss
13780 / 10973 / 6491
Регистрация: 18.12.2011
Сообщений: 29,259
11.10.2021, 19:15
Так, вроде бы это очевидно
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
int x1[4]={1,2,3,4};
int x2[2]={1,2};
int x3[3]={1,2,3,};
int arr[3];
for(int i1=0;i1<4;i1++)
{
  arr[0]=x1[i1];
  for(int i2=0;i2<2;i2++)
  {
     arr[1]=x2[i2];
     for(int i3=0;i3<3;i3++)
     {
        arr[2]=x3[i3];
        for(int j=0;j<3;j++)
          cout<<arr[j]<<' ';
     }
  }
}
0
 Аватар для Helen_2001
15 / 13 / 4
Регистрация: 23.08.2017
Сообщений: 187
11.10.2021, 19:25  [ТС]
Цитата Сообщение от zss Посмотреть сообщение
Так, вроде бы это очевидно
size.arr() может быть не только 3, но и любое другое число.
0
 Аватар для Helen_2001
15 / 13 / 4
Регистрация: 23.08.2017
Сообщений: 187
12.10.2021, 13:04  [ТС]
Цитата Сообщение от zss Посмотреть сообщение
Так, вроде бы это очевидно
Как-то совсем не очевидно

C++
1
2
3
4
5
6
7
8
std::map<std::string, std::vector<int32_t>> arr;
 
  arr.emplace("a",std::vector<int32_t>({1,2,3,4}));
  arr.emplace("b",std::vector<int32_t>({1,2}));
  arr.emplace("c",std::vector<int32_t>({1,2,3}));
......
  arr.emplace("y",std::vector<int32_t>({1,2,3,4,5,6,7,8}));
  arr.emplace("z",std::vector<int32_t>({1,2,3,4,8}));
0
 Аватар для Kastaneda
5232 / 3206 / 362
Регистрация: 12.12.2009
Сообщений: 8,143
Записей в блоге: 2
12.10.2021, 14:27
Helen_2001,
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
#include <map>
#include <vector>
 
int main() {
  std::map<std::string, std::vector<int32_t>> arr;
 
  arr.emplace("a", std::vector<int32_t>({1, 2, 3, 4}));
  arr.emplace("b", std::vector<int32_t>({1, 2}));
  arr.emplace("c", std::vector<int32_t>({1, 2, 3}));
  arr.emplace("y", std::vector<int32_t>({1, 2, 3, 4, 5, 6, 7, 8}));
  arr.emplace("z", std::vector<int32_t>({1, 2, 3, 4, 8}));
 
  for (const auto &array : arr) {
    std::cout << "[ ";
    for (int value : array.second) {
      std::cout << value << " ";
    }
    std::cout << "]" << std::endl;
  }
 
  return 0;
}
0
 Аватар для Helen_2001
15 / 13 / 4
Регистрация: 23.08.2017
Сообщений: 187
12.10.2021, 15:05  [ТС]
Мне нежно вывести не содержимое массива, а перебрать все возможные комбинации значений как я написала выше в примере.
0
Неэпический
 Аватар для Croessmah
18149 / 10731 / 2067
Регистрация: 27.09.2012
Сообщений: 27,035
Записей в блоге: 1
12.10.2021, 16:28
std::next_permutation подойдет?
0
 Аватар для Helen_2001
15 / 13 / 4
Регистрация: 23.08.2017
Сообщений: 187
12.10.2021, 16:36  [ТС]
Цитата Сообщение от Croessmah Посмотреть сообщение
std::next_permutation подойдет?
Вроде нет. Мне нужно брать по одному числу из каждого map..second. Но при этом значений должно быть фиксированно числу arr.size()
0
 Аватар для Helen_2001
15 / 13 / 4
Регистрация: 23.08.2017
Сообщений: 187
13.10.2021, 12:44  [ТС]
Так ничего и не придумала. Пришлось сделать плохо-плохо.
Создала массив, в который заполняются случаным образом данные с проверкой на уникальность. Получилось что-то вроде брутфорса.
Работает долго, но важен результат! Хорошо что никто не видит что внутри кода )
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
13.10.2021, 13:15
Цитата Сообщение от Helen_2001 Посмотреть сообщение
Так ничего и не придумала.
https://rosettacode.org/wiki/C... ns#C.2B.2B
0
13.10.2021, 14:22

Не по теме:

Цитата Сообщение от Helen_2001 Посмотреть сообщение
Мне нежно вывести
Helen_2001, ох :)

0
 Аватар для Helen_2001
15 / 13 / 4
Регистрация: 23.08.2017
Сообщений: 187
13.10.2021, 14:27  [ТС]
Цитата Сообщение от zayats80888 Посмотреть сообщение
https://rosettacode.org/wiki/C... ns#C.2B.2B
Длина arr[].second разная. Не подходит.
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
13.10.2021, 14:29
Цитата Сообщение от Helen_2001 Посмотреть сообщение
Длина arr[].second разная. Не подходит.
В каком месте не подходит?
0
 Аватар для Helen_2001
15 / 13 / 4
Регистрация: 23.08.2017
Сообщений: 187
13.10.2021, 14:33  [ТС]
Цитата Сообщение от zayats80888 Посмотреть сообщение
В каком месте не подходит?
Ваш пример генерирует всё что в std::vector. А мне нужно взять по одному значению из вектора каждой итерации map
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
13.10.2021, 15:22
Цитата Сообщение от Helen_2001 Посмотреть сообщение
А мне нужно взять по одному значению из вектора каждой итерации map
Т.е. в вашем примере на первой позиции могут быть только числа {1,2,3,4}, а на второй позиции только {1, 2}?
0
 Аватар для Helen_2001
15 / 13 / 4
Регистрация: 23.08.2017
Сообщений: 187
13.10.2021, 16:09  [ТС]
Цитата Сообщение от zayats80888 Посмотреть сообщение
Т.е. в вашем примере на первой позиции могут быть только числа {1,2,3,4}, а на второй позиции только {1, 2}?
C++
1
2
3
4
5
6
7
8
  std::map<std::string, std::vector<int32_t>> arr;
 
  arr.emplace("a",std::vector<int32_t>({1,2,3,4}));
  arr.emplace("b",std::vector<int32_t>({1,2}));
  arr.emplace("c",std::vector<int32_t>({1,2,3}));
......
  arr.emplace("y",std::vector<int32_t>({1,2,3,4,5,6,7,8}));
  arr.emplace("z",std::vector<int32_t>({1,2,3,4,8}));
из arr[0].second взять любой из 1,2,3 или 4. Это не важно какой тип вектора, главное массив там разной длины и нужно из него взять какое то одно значение.
потом идем в arr[1] и по той же схеме берем одно значение, скажем 1.

например получился массив
C++
1
2
  arr.emplace("a",std::vector<int32_t>({5,2));
  arr.emplace("b",std::vector<int32_t>({7}));
arr.siz() = 2 следовательно комбинаций будет

5 7
2 7

длина комбинаций,это arr.size() и по одному из second карты.
Мы генерируем все перечисления сверху виз.
И как это сделать я не пойму Я придумала только случайно заполнить и проверить на уникальность
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
13.10.2021, 16:11
Лучший ответ Сообщение было отмечено Helen_2001 как решение

Решение

Helen_2001,
Кликните здесь для просмотра всего текста
C++
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
39
40
41
42
43
44
45
#include <cassert>
#include <cstdint>
#include <iostream>
#include <map>
#include <string>
#include <vector>
#include <functional>
 
int main() {
  std::map<std::string, std::vector<int32_t>> arr;
 
  arr.emplace("a", std::vector<int32_t>({1, 2, 3, 4}));
  arr.emplace("b", std::vector<int32_t>({1, 2}));
  arr.emplace("c", std::vector<int32_t>({1, 2, 3}));
 
  ////////////////////////////////////////////////////
  using VecElement =
      std::pair<size_t, std::reference_wrapper<std::vector<int32_t> const>>;
  std::vector<VecElement> comb;
  for (auto const &p : arr) {
    assert(!p.second.empty());
    comb.emplace_back(0, p.second);
  }
  auto print = [&comb]() {
    std::cout << "[ ";
    for (auto p : comb) {
      std::cout << p.second.get()[p.first] << ' ';
    }
    std::cout << "]\n";
  };
  for (bool finish = comb.empty(); !finish;) {
    print();
    size_t i = 0;
    ++comb[i].first;
    for (; comb[i].first == comb[i].second.get().size();) {
      comb[i++].first = 0;
      if (i == comb.size()) {
        finish = true;
        break;
      }
      ++comb[i].first;
    }
  }
  ////////////////////////////////////////////////////
}
1
4949 / 2289 / 287
Регистрация: 01.03.2013
Сообщений: 5,991
Записей в блоге: 32
13.10.2021, 16:57
Семен Семеныч!... (С)
C++
1
2
3
4
5
6
7
8
9
10
11
#include <iostream>
#include <vector>
#include <string>
 
std::vector<std::vector<int32_t>> v = {{1,2,3,4}, {1,2}, {1,2,3}};
 
void f (int i, std::string r) {
    if (i<0) std::cout << r << "\n"; else for (int j=0; j<v[i].size(); j++) f(i-1, std::to_string(v[i][j])+" "+r);
}
 
int main() { f(v.size()-1, ""); }
ЗЫ убогие индексы и глобальный доступ надо заменить на итераторы, но сами курите как их в плюсах инкрементировать и чекать выход за границы
ЗЗЫ выучите хотя бы один нормальный язык, и подобные задачки не будут вызывать никаких трудностей
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.10.2021, 16:57
Помогаю со студенческими работами здесь

Перебор комбинаций
Здравствуйте! Возникла такая задача. Дан одномерный массив из N цифр,нужно составить все возможные комбинации чисел из этих цифр(числа...

Перебор комбинаций объектов
Привет! Прошу помощи с написанием программы по перебору комбинаций объектов. Сразу оговорюсь, что в реальной жизни к программированию...

Перебор комбинаций с исключениями
Здраствуйте!Хочу попробовать сделать задачу:есть число n которое указывает количество цифр и есть число k которое указывает количество...

Как сделать перебор комбинаций?
Доброго времени суток! Есть массив символов и надо перетасовать и вывести их во всех возможных вариантах. #include &lt;windows.h&gt; ...

Перебор всевозможных комбинаций, изменяемая длина и диапазон
Обгуглился уже, где - то может и видел то, что нужно, но в силу тупизны счёл не тем. Брут в общем. Есть длина строки, массив с...


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

Или воспользуйтесь поиском по форуму:
18
Ответ Создать тему
Новые блоги и статьи
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru