Cod sursa(job #1457604)

Utilizator tony.hegyesAntonius Cezar Hegyes tony.hegyes Data 3 iulie 2015 18:20:47
Problema Combinari Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.97 kb
#include <fstream>
#include <iostream>
using namespace std;

///// DESCRIPTION
// THIS PROGRAM FINDS ALL COMBINATIONS
// OF NUMBERS BETWEEN 1 AND n
// BY USING BACKTRACKING
/////

void combinations(ostream&, int, int, int[], int, int);
void output(ostream&, int[], int);

int main(int argc, char **argv)
{
	// INPUT
	int n, k;
	
	ifstream indata("combinari.in");
	indata >> n >> k;
	indata.close();
	
	// GENERATION AND OUTPUT OF PERMUTATIONS
	ofstream outdata("combinari.out");
	
	int stack[k];
	combinations(outdata, n, k, stack, 0, 1);

	outdata.close();
	
	return 0;
}

void combinations(ostream& outdata, int n, int k, int stack[], int step, int start) {
	for (int i = start; i <= n; i++) {
		stack[step] = i;
		
		if (step < k - 1) {
			combinations(outdata, n, k, stack, step + 1, i + 1);
		} else {
			output(outdata, stack, k);
		}
	}
}

void output(ostream& outdata, int permutation[], int n) {
	for (int i = 0; i < n; i++) {
		outdata << permutation[i] << " ";
	}
	outdata << "\n";
}