记录编号 137732 评测结果 AAAAAAAAAA
题目名称 分组 最终得分 100
用户昵称 GravatarRP++ 是否通过 通过
代码语言 C++ 运行时间 0.003 s
提交时间 2014-11-05 07:57:10 内存使用 0.32 MiB
显示代码纯文本
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>

using namespace std;

int sum,k;
int tot=0;
int print[20]={0};
int ans[100][20]={0};

void dfs(int s,int res)
{
	for(int i=s;i<=(sum-res)/(k-print[0]);i++)
	{
		print[++print[0]]=i;
		res+=i;
		if(print[0]+1==k)
		{
			print[++print[0]]=sum-res;
			memcpy(ans[++tot],print,sizeof(print));
			print[0]--;
		}
		else dfs(i,res);
		print[0]--;
		res-=i;
	}
}

int main()
{
	freopen("dataa.in","r",stdin);
	freopen("dataa.out","w",stdout);
	scanf("%d%d",&sum,&k);
	dfs(1,0);
	printf("%d\n",tot);
	for(int i=1;i<=tot;i++)
	{
		for(int j=1;j<=k;j++)
		{
			printf("%d ",ans[i][j]);
		}
		printf("\n");
	}
}