6 / 6 / 0
Регистрация: 14.02.2018
Сообщений: 60

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

14.02.2018, 21:13. Показов 6982. Ответов 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru