ในปัญหานี้ เราได้รับอาร์เรย์และเราต้องพิมพ์ชุดย่อยทั้งหมดของขนาด r ที่กำหนด ซึ่งสามารถเกิดขึ้นได้โดยใช้องค์ประกอบของอาร์เรย์
มาดูตัวอย่างเพื่อทำความเข้าใจหัวข้อกันดีกว่า −
Input: array = {3, 5, 6} r = 2 Output: 3 5 3 6 5 6
ในปัญหานี้ เราจะต้องหาผลรวมของตัวเลขในอาร์เรย์ทั้งหมด และไม่รวมชุดค่าผสม r บิตที่มีอยู่ในชุดแล้ว
ตัวอย่าง
#include <iostream> using namespace std; void printSubset(int arr[], int n, int r, int index, int data[], int i); int main(){ int arr[] = {3 , 5, 6}; int r = 2; cout<<"The sets are : "; int n = sizeof(arr) / sizeof(arr[0]); int data[r]; printSubset(arr, n, r, 0, data, 0); return 0; } void printSubset(int arr[], int n, int r, int index, int data[], int i){ if (index == r) { for (int j = 0; j < r; j++) cout<<data[j]<<" "; cout<<endl; return; } if (i >= n) return; data[index] = arr[i]; printSubset(arr, n, r, index + 1, data, i + 1); printSubset(arr, n, r, index, data, i + 1); }
ผลลัพธ์
เซตคือ −
3 5 3 6 5 6