Упражнения на C: вывести все возможные комбинации r элементов в данном массиве
C Массив: упражнение-82 с раствором
Напишите программу на C для печати всех возможных комбинаций r элементов в данном массиве.
Пример решения:
Код C:
#include <stdio.h>
void makeCombination(int arr1[], int data[], int st, int end,
int index, int r);
void CombinationDisplay(int arr1[], int n, int r)
{
int data[r];
makeCombination(arr1, data, 0, n-1, 0, r);
}
void makeCombination(int arr1[], int data[], int st, int end,
int index, int r)
{
if (index == r)
{
for (int j=0; j<r; j++)
printf("%d ", data[j]);
printf("\n");
return;
}
for (int i=st; i<=end && end-i+1 >= r-index; i++)
{
data[index] = arr1[i];
makeCombination(arr1, data, i+1, end, index+1, r);
}
}
int main()
{
int arr1[] = {1, 5, 4, 6, 8};
int r = 4,i;
int n = sizeof(arr1)/sizeof(arr1[0]);
//------------- print original array ------------------
printf("The given array is: \n");
for(i = 0; i < n; i++)
{
printf("%d ", arr1[i]);
}
printf("\n");
//------------------------------------------------------
printf("The combination from by the number of elements are: %d\n",r);
printf("The combinations are: \n");
CombinationDisplay(arr1, n, r);
}
Пример вывода:
Данный массив: 1 5 4 6 8 Комбинации по количеству элементов: 3 Комбинации: 1 5 4 6 1 5 4 8 1 5 6 8 1 4 6 8 5 4 6 8
Блок-схема 1:
Блок-схема 2:
Редактор кода программирования C:
Улучшите этот пример решения и опубликуйте свой код через Disqus.
Предыдущий: Напишите программу на C, чтобы найти максимальное число повторений в данном массиве. Диапазон массива - [0..n-1], а элементы находятся в диапазоне [0..k-1] и k <= n ,
Далее: написать программу на C, чтобы найти пару с заданной разницей.
Новый контент: Composer: менеджер зависимостей для PHP , R программирования
disqus2code