Cod sursa(job #954192)

Utilizator radu33Nesiu Radu radu33 Data 28 mai 2013 16:54:28
Problema Combinari Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.68 kb
#include<fstream>
using namespace std;

int a[20], n, k;
ifstream fin("combinari.in");
ofstream fout("combinari.out");

void afis()
{
	int i;
	for(i = 1; i <= k; i++)
		fout << a[i] << " ";
	fout << '\n';
}

void back()
{
	int p = 1; // p = pozitia din cele k elemente pe care vom incerca sa punem urmatorul numar
	while(p > 0)
	{
		if(p == k + 1)
		{
			afis();
			p--;
		}
		else
		{
			if(a[p] == n)
				p--; // backtrack
			else
			{
				a[p]++;
				p++;
				a[p] = a[p-1];
				// cautarea pt urmatorul element va incepe sigur de la numarul curent (combinarile vor fi in ord. cresc)
			}
		}
	}
}

int main()
{
	fin >> n >> k;
	back();
	return 0;
}