|
2 / 2 / 0
Регистрация: 15.12.2019
Сообщений: 94
|
||||||
Как вывести все подмножества множества A?21.03.2020, 09:35. Показов 9339. Ответов 11
Метки нет (Все метки)
Допустим есть 1,2,3
Должно вывести: 1 1,2 1,2,3 1,3 2 2,3 3
0
|
||||||
| 21.03.2020, 09:35 | |
|
Ответы с готовыми решениями:
11
Задача, сгенерировать все k-элементные подмножества множества
|
|
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
|
||||||
| 21.03.2020, 10:22 | ||||||
1
|
||||||
|
2081 / 1239 / 464
Регистрация: 20.12.2014
Сообщений: 3,234
|
||||||
| 21.03.2020, 10:25 | ||||||
|
Ну, а если нужно "по-простому", то так:
0
|
||||||
|
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
|
|||||||||||
| 21.03.2020, 11:03 | |||||||||||
|
Pufik11, chumich, если нужно только печатать числа, то так:
Добавлено через 6 минут Если в псевдо-подмножествах нужен разделитель-запятая, то чуть надо изменить вывод:
0
|
|||||||||||
|
2 / 2 / 0
Регистрация: 15.12.2019
Сообщений: 94
|
|
| 21.03.2020, 11:11 [ТС] | |
|
А что значит y-1? Зачем он
0
|
|
|
2081 / 1239 / 464
Регистрация: 20.12.2014
Сообщений: 3,234
|
||
| 21.03.2020, 11:22 | ||
|
0
|
||
|
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
|
|
| 21.03.2020, 11:27 | |
|
Pufik11, chumich, кстати да. Если используем исходный массив, то от него переменная y осталась ))
Я забыл уже про неё )))) Вместо mas.Length можно написать y
0
|
|
|
2 / 2 / 0
Регистрация: 15.12.2019
Сообщений: 94
|
|
| 21.03.2020, 11:28 [ТС] | |
|
Проблема в другом, у меня есть вариант как должно находить подмножества, а в программе у arm row, оно находит не всё
0
|
|
|
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
|
|
| 21.03.2020, 11:46 | |
|
Pufik11, народ предложил ухищрения через эмуляцию двоичного кода.
Найти все подмножества множества Задача, получается, явно не для новичка ))
0
|
|
|
96 / 55 / 23
Регистрация: 01.05.2017
Сообщений: 78
|
|||||||||||
| 21.03.2020, 11:53 | |||||||||||
|
Каждому подмножеству можно поставить в соответствие характеристический вектор из нулей и единиц.
К примеру для множества A = {a, b, c, d} (считаем, что в массиве элементы лежат в таком порядке, как я записал), некоторые подмножества и соответствующие им вектора таковы: { } ~ (0,0,0,0) {a} ~ (1,0,0,0) {a,c} ~ (1,0,1,0) {a,c,d} ~ (1,0,1,1) Каждый характеристический вектор можно воспринимать как двоичное число. А каждому двоичному числу соответствует десятичное. Таким образом, перебирая все десятичные числа от 0 до 24-1 можно перебрать все подмножества A. Если элементов во множестве A было бы n, то подмножеств было бы 2n, так что перебирали бы от 0 до 2n-1. То есть 0 ~ (0,0,0,0) ~ { } 1 ~ (0,0,0,1) ~ {d} 2 ~ (0,0,1,0) ~ {c} ... 10 ~ (1,0,1,0) ~ {a,c} ... 15 ~ (1,1,1,1) ~ {a,b,c,d} Сейчас начну писать код и окажется, что вектора удобней в обратном порядке читать, что не существенно. Теперь вопрос, как перебирая целые числа в нужном диапазоне получать на их основе подмножества. Для этого пригодятся побитовые операции над целыми числами. В коде ниже как раз этот перебор и 1<<mas.Length для получения нужной степени двойки.
0001 ~ 1 0010 ~ 2 0100 ~ 4 1000 ~ 8 которые, являются степенями двойки (степень двойки получаем операцией 1<<p). Если в результате поэлементной конъюнкции получится 0, значит бит равен нулю, иначе единице. И если бит равен единице, то из переменной mas можно печатать элемент. Кликните здесь для просмотра всего текста
Не стал добавлять запятые между элементами и фигурные скобки, чтобы не усложнять. Имейте в виду, что пустое множество тоже выводится. Или нужен именно такой вывод, как указан? Тогда я всё это зря писал
0
|
|||||||||||
|
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
|
|||||||||||
| 21.03.2020, 13:36 | |||||||||||
|
У меня на основе двоичной системы соответствия элементам так получилось:
Добавлено через 1 минуту ---- Не. Ну тут явно под дурака косить не получится. Если не списывать, то студент явно должен хорошо знать алгебру. Добавлено через 12 минут ---- С принудительным упорядочением результата с помощью Array.Sort():
--- В обсуждениях мелькала мысль - если мы хотим, чтобы в множестве было много элементов (больше разрядности целого числа), то надо делать служебный массив булевых значений присутствия/отсутствия. Соответственно, "инкремент" счетчика для булевых переключателей придется написать самостоятельно.
0
|
|||||||||||
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
||||||
| 21.03.2020, 14:35 | ||||||
|
Пустое подмножество — тоже элемент множества.
1
|
||||||
| 21.03.2020, 14:35 | |
|
Помогаю со студенческими работами здесь
12
Рекурсия: вывести все подмножества множества А
Рекурсия: вывести на дисплей все возможные подмножества множества
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip
На первой гифке отладочные линии отключены, а на второй включены:. . .
|
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем.
. . .
|
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
|
|
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
|
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|