кодесурса
«C

Упражнения на C: вывести все возможные комбинации r элементов в данном массиве

script1adsense2code
script1adsense3code

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 программирования


script1adsense4code
script1adsense5code
disqus2code
script1adsense6code
script1adsense7code
buysellads2code