Pagini recente » Cod sursa (job #10231) | Cod sursa (job #1372292) | Cod sursa (job #2971354) | Borderou de evaluare (job #1036897) | Cod sursa (job #685751)
Cod sursa(job #685751)
#include<fstream>
using namespace std;
ifstream in("combinari.in");
ofstream out("combinari.out");
int st[20], n, k, p;
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++)
out<<st[i]<<" ";
out<<endl;
}
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)
{
in>>n;
in>>p;
back();
in.close();
out.close();
return 0;
}