Cod sursa(job #685754)

Utilizator dsfm_danielaasd mghd dsfm_daniel Data 21 februarie 2012 10:11:17
Problema Combinari Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.78 kb
#include<stdio.h>
using namespace std;

int st[20], n, k, p;
 
FILE *f2=fopen("combinari.out","w");
void init(int k)
{
	if(k==1)
	st[k]=0;
	else
	st[k]=st[k-1];
}
int succesor(int k)
{
	if(st[k]<(n-p+k))
	{
		st[k]=st[k]+1;
		return 1;
	}
	else
	return 0;
}
int valid(int k)
{
	return 1;
}
int solutie(int k)
{
	if(k==p)
	return 1;
	return 0;
}
void tipar()
{

	for(int i=1;i<=p;i++)
	fprintf(f2,"%d ",st[i]);
	fprintf(f2,"\n");
}
void back()
{
	k=1;init(k);
	while(k>0)
	{
		while(succesor(k))
		{if(valid(k))
			if(solutie(k))
			tipar();
			else
			{
				k++;
				init(k);
			}
		}
		k--;
	}
}
int main (void)
{
	FILE *f1;
	f1=fopen("combinari.in","r");
	fscanf(f1,"%d %d",&n,&p);
	back();
	fclose(f1);
	fclose(f2);
	return 0;
}