اكتب برنامج بلغة C لطباعة كل التركيبات الممكنة لعناصر r في مصفوفة معينة

  • برمجة
  • برمجة سي c

اكتب برنامج بلغة C لطباعة كل التركيبات الممكنة لعناصر r في مصفوفة معينة

الخرج المتوقع :

The given array is:
1  5  4  6  8
The combination from by the number of elements are: 4
The combinations are:
1 5 4 6
1 5 4 8
1 5 6 8
1 4 6 8
5 4 6 8

الأجوبة

/*Write a program in C to print all possible combinations of r elements in a given array*/

#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);
}
هل كان المحتوى مفيد؟

تبحث عن مدرس اونلاين؟

محتاج مساعدة باختيار المدرس الافضل؟ تواصل مع فريقنا الان لمساعدتك بتأمين افضل مدرس
ماهو التخصص الذي تبحث عنه؟
اكتب هنا...