#include<iostream>
using namespace std;
int x[100],n,p,nr=0;
void Write()
{
for(int i=1;i<=p;i++) cout<<x[i]<<" ";
cout<<endl;
nr++;
}
int suma(int k)
{
int s=0;
for(int i=1;i<=k;i++) s=s+x[i];
return s;
}
void Comb(int k)
{ for(int i=x[k-1]+1;i<=n;i++)
{ x[k]=i;
if(suma(k)<=n)
if(k<p) Comb(k+1);
else
if(k==p) if (suma(k)==n) Write();
}
}
int main()
{ cin>>n>>p;
Comb(1);
cout<<nr;
system("pause");
return 0;
}
|