Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.68/34: Рейтинг темы: голосов - 34, средняя оценка - 4.68
6 / 6 / 0
Регистрация: 14.02.2018
Сообщений: 60

Задача, сгенерировать все k-элементные подмножества множества

14.02.2018, 21:13. Показов 6970. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужна помощь с задачей, нужно решить с циклами или как то по другом, но не каких рекурсий тд. тп, данные вводятся с клавиатуры.

Задача: Сгенерировать все k-элементные подмножества множества A из N чисел, A={1, 2, ..., N}.
Пример: N=3, k=2, подмножества {1,2}, {1,3}, {2,3}
Пример: N=4, k=3, подмножества {1,2,3}, {1,2,4}, {2,3,4} {1,3,4}

Заранее спасибо
1
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.02.2018, 21:13
Ответы с готовыми решениями:

Как вывести все подмножества множества A?
Допустим есть 1,2,3 Должно вывести: 1 1,2 1,2,3 1,3 2 2,3 3

Сгенерировать все k -элементные подмножества из N
Дело все в том, что мне надо написать программу, которой на вход давался файл с N целых чисел через пробел, пользователь дает на ввод число...

Перечислить все K элементные подмножества n элементарного множества
Перечислить все K элементные подмножества n элементарного множества пример с вводом выводом

8
 Аватар для irises
140 / 72 / 26
Регистрация: 29.06.2015
Сообщений: 186
14.02.2018, 21:33
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
Random r = new Random();
int n = Convert.ToInt32(Console.ReadLine());
int k = Convert.ToInt32(Console.ReadLine());
int[,] arr = new int[n, k];
for (int i = 0; i < n; i++)
{
    for (int j = 0; j < k; j++)
    {
        arr[i, j] = r.Next(10);
    }
}
for (int i = 0; i < n; i++)
{
    for (int j = 0; j < k; j++)
    {
        Console.Write(arr[i,j]+"\t");
    }
    Console.WriteLine();
}
2
6 / 6 / 0
Регистрация: 14.02.2018
Сообщений: 60
14.02.2018, 22:09  [ТС]
Не совсем так, нужно что бы я вводил число 4 и это был бы массив 1, 2, 3, 4. А в вашем случае будет генерироваться рандомное значение
1
 Аватар для irises
140 / 72 / 26
Регистрация: 29.06.2015
Сообщений: 186
14.02.2018, 22:41
Цитата Сообщение от Deaadfox Посмотреть сообщение
нужно что бы я вводил число 4 и это был бы массив 1, 2, 3, 4
Тогда вместо этого:
C#
1
arr[i, j] = r.Next(10);
можна написать так:
C#
1
arr[i, j] = j;
1
6 / 6 / 0
Регистрация: 14.02.2018
Сообщений: 60
15.02.2018, 20:24  [ТС]
Тоже не подходит, в консоле для размера 4 и подмножеств 3 вывело вот это {0,1,2}, {0,1,2}, {0,1,2}, {0,1,2}
1
 Аватар для irises
140 / 72 / 26
Регистрация: 29.06.2015
Сообщений: 186
16.02.2018, 10:52
Цитата Сообщение от Deaadfox Посмотреть сообщение
Тоже не подходит, в консоле для размера 4 и подмножеств 3 вывело вот это {0,1,2}, {0,1,2}, {0,1,2}, {0,1,2}
А как должно вывести? Начиная с 1?

C#
1
arr[i, j] = j+1;
1
6 / 6 / 0
Регистрация: 14.02.2018
Сообщений: 60
16.02.2018, 19:46  [ТС]
Вот пример, я ввожу N=4, k=3 и должно вывести подмножества {1,2,3}, {1,2,4}, {2,3,4} {1,3,4}, а в твоем случае оно тогда будет виводить {1,2, 3}, {1,2, 3}, {1,2, 3}, {1,2, 3}

Добавлено через 1 минуту
Ну и ещё ты просто сделал двумерный массив, а мне нужно что бы оно ещё и свойства перебирало
1
3566 / 2507 / 1174
Регистрация: 14.08.2016
Сообщений: 8,219
16.02.2018, 22:31
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
var n = 4;
            var k = 3;
 
            var a = new int[k];
            for (int i = 0; i < k; i++)
            {
                a[i] = i + 1;
            }
            var p = k;
            while (p>=0)
            {
                Console.WriteLine("{" + string.Join(",",a) + "}");
                p = a[k - 1] == n ? p - 1 : k - 1;
                if(p>=0)
                {
                    for (int i = k - 1; i >= p; i--)
                    {
                        a[i] = a[p] + i - p + 1;
                    }
                }
            }
2
6 / 6 / 0
Регистрация: 14.02.2018
Сообщений: 60
17.02.2018, 12:13  [ТС]
Спасибо, все отлично сделано, то что мне нужно, я ещё немного изменил код.

ТЕМА ЗАКРЫТА
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
17.02.2018, 12:13
Помогаю со студенческими работами здесь

Перечислить все K элементные подмножества n элементарного множества
Перечислить все K элементные подмножества n элементарного множества пример и объяснение по этой задачи на Си++

Перечислить все K элементные подмножества n элементного множества
Например: есть множество 1, 2, 3 N=3, k=2, на выводе должны получить: 1 2 1 3 2 3

Разработать программу, которая генерирует все k-элементные подмножества множества n
Разработать алгоритм генерации всех k-элементов подмножества n-элементного множества в лексикографическом порядке. Перестановки множества...

Сгенерировать все подмножества данного n-элементного множества {0,., n-1}
Сгенерировать все подмножества данного n-элементного множества {0,.., n-1} нашел алгоритм для этой задачи Заведем массив B из (n+1)...

Сгенерировать все подмножества
Сгенерировать все подмножества данного n-элементного множества {0,..., n-1}. это вообще как сделать? О_О Добавлено через 22 часа...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта 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 На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru