Pagini recente » Autentificare | Istoria paginii runda/suma1/clasament | Istoria paginii runda/simumaster | Istoria paginii runda/antrenament_2/clasament | Cod sursa (job #156986)
Cod sursa(job #156986)
#include <fstream.h>
int n,k,p,st[25];
ifstream f("combinari.in");
ofstream g("combinari.out");
int valid (int p)
{
if (p>=2) if (st[p]<st[p-1]) return 0;
for (register i=1;i<=p-1;i++)
if (st[p]==st[i]) return 0;
return 1;
}
void back(int p)
{for (register i=st[p-1]+1; i<=n;i++)
{
st[p]=i;
if (valid(p)) if (p==k){ for (int j=1; j<=p;j++)
g<<st[j]<<' ';
g<<'\n' ;
}
else back(p+1);
}
}
int main()
{
f>>n>>k;
st[0]=0;
back(1);
f.close();
g.close();
return 0;
}