Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 23.11.2019
Сообщений: 32

Из N по M генератор

08.02.2022, 07:34. Показов 955. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать программу, генерирующую для числового множества из n элементов сочетания по m элементов.
Входные данные: n, m, множество. Выходные данные: все упорядоченные сочетания

Видел на форуме похожие темы, но результат не тот по итогу.

Есть код, который выполняет из n по m.
А в заданий входным данным является множество, т.е нужно ввести допустим как сочетаешь и ввести числа которые будут сочетаться. Внизу на скрине пример как должна работать.


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
#include <iostream>
using namespace std;
bool NextSet(int* a, int n, int m)
{
    int j = m - 1;
    while (a[j] == n && j >= 0) j--;
    if (j < 0) return false;
    if (a[j] >= n)
        j--;
    a[j]++;
    if (j == m - 1) return true;
    for (int k = j + 1; k < m; k++)
        a[k] = a[j];
    return true;
}
void Print(int* a, int n)
{
    static int num = 1;
    cout.width(3);
    cout << num++ << ": ";
    for (int i = 0; i < n; i++)
        cout << a[i] << " ";
    cout << endl;
}
int main()
{
    int n, m, * a;
    cout << "N = ";
    cin >> n;
    cout << "M = ";
    cin >> m;
    int h = n > m ? n : m; // размер массива а выбирается как max(n,m)
    a = new int[h];
    for (int i = 0; i < h; i++)
        a[i] = 1;
    Print(a, m);
    while (NextSet(a, n, m))
        Print(a, m);
    cin.get(); cin.get();
    return 0;
}
Миниатюры
Из N по M генератор  
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.02.2022, 07:34
Ответы с готовыми решениями:

Напишите генератор списка, который заполняет список данными, которые вводит пользователь. Другой генератор списка должен
Напишите генератор списка, который заполняет список данными, которые вводит пользователь. Другой генератор списка должен преобразовывать...

Генератор паролей, функция генератор
import random from string import ascii_lowercase, ascii_uppercase random.seed(1) def randompassword(n): chars =...

Генератор комплексных чисел. Генератор гауссовских целых чисел
rand(1,n) - генерирует случайные числа, нормально распределенные на . Есть ли аналогичный генератор для комплексных чисел? В частности...

9
 Аватар для YUEN HOIFEF
252 / 185 / 47
Регистрация: 31.01.2021
Сообщений: 934
08.02.2022, 09:48
Внизу на скрине пример как должна работать.
По моему неправильный вывод. На четвертом скрине, например, где
194
196
197
192
и т.д.

Добавлено через 4 минуты
Во вторых - может ли быть m > n?
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,536
Записей в блоге: 1
08.02.2022, 11:52
YUEN HOIFEF, есть 1 4 9, что ты кипишуешь? Это сочетания, а не перестановки с сочетаниями.

Добавлено через 1 минуту
Цитата Сообщение от Strelok-R Посмотреть сообщение
Есть код, который выполняет из n по m.
А в заданий входным данным является множество
всё просто, не выводить сгенерированное сочетание, а использовать его числа как индексы во введённом массиве.
0
0 / 0 / 0
Регистрация: 23.11.2019
Сообщений: 32
08.02.2022, 13:21  [ТС]
YUEN HOIFEF,
Там просто сочетания, оно по порядку выводит.

Kuzia domovenok,
А можешь показать как это выглядеть будет?
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,536
Записей в блоге: 1
08.02.2022, 13:33
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
46
#include <iostream>
using namespace std;
bool NextSet(int* a, int n, int m)
{
    int j = m - 1;
    while (a[j] == n && j >= 0) j--;
    if (j < 0) return false;
    if (a[j] >= n)
        j--;
    a[j]++;
    if (j == m - 1) return true;
    for (int k = j + 1; k < m; k++)
        a[k] = a[j];
    return true;
}
void Print(int* a,int* indices, int n)
{
    static int num = 1;
    cout.width(3);
    cout << num++ << ": ";
    for (int i = 0; i < n; i++)
        cout << a[ indices[i] ] << " ";
    cout << endl;
}
int main()
{
    int n, m, * a;
    cout << "N = ";
    cin >> n;
    cout << "M = ";
    cin >> m;
    int h = n > m ? n : m; // размер массива а выбирается как max(n,m)
    a = new int[h];
    int *ind = new int[h];
    
    for (int i = 0; i < h; i++)
    {
        cout<<"a["<<i<<"]=";
        cin>>a[i];
        ind[i]=i;
    }
    while (NextSet(ind, n, m))
        Print(a, ind, m);
    cin.get(); cin.get();
    return 0;
}
0
0 / 0 / 0
Регистрация: 23.11.2019
Сообщений: 32
08.02.2022, 13:51  [ТС]
Kuzia domovenok, А тип вопрос тогда, по работе. В старом от как бы сочетания делает, а тут он с первого числа куда-то данные теряет, так же не должно быть или тип тут что-то по другому?
Миниатюры
Из N по M генератор   Из N по M генератор  
0
 Аватар для YUEN HOIFEF
252 / 185 / 47
Регистрация: 31.01.2021
Сообщений: 934
08.02.2022, 14:01

Kuzia domovenok

что ты кипишуешь?
Не ты, а ВЫ. Как с дяденькой разговариваешь? В угол посавлю.
0
 Аватар для YUEN HOIFEF
252 / 185 / 47
Регистрация: 31.01.2021
Сообщений: 934
11.02.2022, 12:16
Лучший ответ Сообщение было отмечено Strelok-R как решение

Решение

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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#include<iostream>
#include<iomanip>
 
 
 
 
 
#define cN sizeof(matrix) / sizeof(matrix[ 0 ])
 
 
 
 
 
 
void shift_mx( int *matrix, int MN, int start )
 {
for( int i=start, tmp; i<MN-1; i++ )
 {
 tmp = matrix[ i ];
 matrix[ i ] = matrix[ i+1 ];
 matrix[ i+1 ] = tmp;
 }
 }
 
 
 
 
 
 
void show_mx( const int *matrix, const int N, const int M )
 {
static int counter = 0;
for( int j=0; j<N; j++ )
 {
 if( j <= M-1 ) std::cout << std::setw(3) << matrix[ j ];
 
/*
 std::cout << std::setw(3) << matrix[ j ];
 if( j == M-1 ) std::cout << std::setw(2) << "|";
*/
 }
 
//std::cout << std::setw(8) << ++counter;
std::cout << std::endl;
 }
 
 
void reverce_mx( int *matrix, const int S, const int E )
 {
for( int j=E-1, i=S, tmp; i<=E/2; i++, j-- )
 {
 tmp = matrix[ i ];
 matrix[ i ] = matrix[ j ];
 matrix[ j ] = tmp;
 }
 }
 
 
 
 
void shiftec( int *matrix, int N, int pos, int chx )
 {
for( int i=0; i<N-pos; i++ )
 {
 show_mx( matrix, N, pos+1 );
 shift_mx( matrix, N, pos );
 }
 }
 
 
 
 
 
 
void exec( int *matrix, int N, int M, int cnt )
 {
int pos = M - 1;
static int xN = N;
 
shiftec( matrix, N, pos, 0 );
 
if( !pos ) return;
 
shift_mx( matrix, N, pos-1 );
 
if( cnt == (pos) )
 {
 if( cnt-1==0 ) return;
 
 cnt = xN;
 N = xN--;
 
 if( N==M ) return;
 shift_mx( matrix, N, pos-2 );
 reverce_mx( matrix, pos-2, N-1 );
 }
 
 
exec( matrix, N-1, M, cnt-1 );
 }
 
 
 
 
int main()
 {
int matrix[] = { 1, 2, 4, 6, 7, 9 };
 
const int M = 3;
int N;
N = cN;
 
 
exec( matrix, N, M, N );
 
std::cout <<  "\n ----- ENDE ----- \n";
std::cin.get();
return 0;
 }
всё просто
Прям проще простого.
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,536
Записей в блоге: 1
11.02.2022, 12:28
YUEN HOIFEF, ну дружище, вот сейчас и правда стало всё сложно. Откуда так много функций? Откуда столько телодвижений?
Почему сдвиг выполняется перестановкой, а не простым matrix[ i ] = matrix[ i+1 ];
почему exec рекурсивная?
Оригинальная программа автора была намного проще для понимания, ИМХО.
0
 Аватар для YUEN HOIFEF
252 / 185 / 47
Регистрация: 31.01.2021
Сообщений: 934
11.02.2022, 12:50
Откуда столько телодвижений

Ну что на это сказать. Как то пошло так да и пошло..
Кстати еще недоделанный оказался код.
Как говорится: - Слишком хорошо, тоже не хорошо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.02.2022, 12:50
Помогаю со студенческими работами здесь

Генератор
Доброго дня. Как можно сделать в аксесе 2007 в таблице поле с генератором случайных чисел шестизначного размера? Есть ли такая...

Генератор
Пишу лабу нужно написать генератор псевдослучайных чисел методом Фон Неймана х0 = 0.2152, возводится в квадрат: ( х0 )2 =...

генератор
Собрал вот такую схему генератора https://ru.otyexpress.som/item/DDS-Func ... bed42c3378 но так как оно в корпусе гнезда поставил не на...

Генератор
Доброго времени суток. Подскажите пожалуйста, стоит задача сделать генератор строки, состоящий из 9 символов. Есть массив элементов ...

Генератор
У меня стоит такая задача, дан массив одномерный, в котором 10 элементов. Надо чтобы каждый элемент массива генерировался случайно и без...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
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