Pagini recente » Cod sursa (job #1130812) | Cod sursa (job #929028) | Cod sursa (job #1298416) | Cod sursa (job #1158067) | Cod sursa (job #572598)
Cod sursa(job #572598)
#include<fstream>
using namespace std;
ifstream f("f.in");
ofstream g("f.out");
int n,i,k,s,p,v[100],x[100];
int succesor(int k)
{if (x[k]<n&&k<=p)
{x[k]++;
return 1;
}
return 0;
}
int valid (int k)
{int i;
s=0;
for(i=1;i<=k;i++)
s=s+x[i];
if (s>n)
return 0;
return 1;
}
void back()
{int i,k;
k=1;
x[k]=0;
while (k>0)
{i=0;
while (i==0&&succesor(k))
if (valid (k))
i=1;
if (i==0)
k--;
else
if (k==p&&s==n)
{for (i=1;i<=k;i++)
g<<x[i]<<" ";
g<<'\n';
}
else
{k++;
x[k]=x[k-1];
}
}
}
int main()
{f>>n>>p;
back();
f.close();
g.close();
return 0;
}