Pagini recente » Cod sursa (job #668058) | Cod sursa (job #2150449) | Cod sursa (job #282255) | Cod sursa (job #863965) | Cod sursa (job #685754)
Cod sursa(job #685754)
#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;
}