Pagini recente » Rezultatele filtrării | Diferente pentru problema/oneouts intre reviziile 9 si 10 | Cod sursa (job #1633129) | Borderou de evaluare (job #1247388) | Cod sursa (job #699944)
Cod sursa(job #699944)
#include <fstream>
using namespace std;
ifstream f("combinari.in");
ofstream g("combinari.out");
int st[20];
int n,s,i,k,as,ev;
void init()
{
if (k==1) st[k]=0;
else st[k]=st[k-1];
}
int succesor()
{
if (st[k]<n)
{
st[k]++;
return 1;
}
return 0;
}
int valid()
{
return 1;
}
int solutie()
{
return (k==s);
}
void tipar()
{
for (i=1;i<=k;i++)
g<<st[i]<<' ';
g<<'\n';
}
void back()
{
k=1;
init();
while (k)
{
as=1;
ev=0;
while (as && !ev)
{
as=succesor();
if (as)
ev=valid();
}
if (as)
{
if (solutie()) tipar();
else
{
k++;
init();
}
}
else k--;
}
}
int main()
{
f>>n>>s;
back();
g.close();
return 0;
}