记录编号 394809 评测结果 AAAAAAAAAA
题目名称 [网络流24题] 圆桌聚餐 最终得分 100
用户昵称 GravatarJustWB 是否通过 通过
代码语言 C++ 运行时间 0.007 s
提交时间 2017-04-14 16:47:14 内存使用 0.60 MiB
显示代码纯文本
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
int n,m;
struct NN
{
	int N;
	int now;
	NN(){N=0;now=0;}
	bool operator < (const NN a)const
	{
		return N>a.N;
	}
}N[271];
struct MM
{
	int M;
	int now;
	int q[271],wei;
	MM()
	{
	M=0;
	now=0;
	memset(q,0,sizeof(q));wei=1;
	}
	void push(int l)
	{
		q[wei]=l;wei++;
	}
	void out()
	{
		for(int i=1;i<wei;i++)
		{
			printf("%d ",q[i]);
		}
		printf("\n");
	}
}M[271];
bool tmpa(MM a,MM b)
{
	return a.M>b.M;
}
bool tmpb(MM a,MM b)
{
	return a.now<b.now;
}
void fp(int now)
{
	for(int i=1;i<=n;i++)
	{
		if(M[now].M==0)break;
		if(N[i].N>0)
		{
			M[now].M--;
			N[i].N--;
			M[now].push(N[i].now);
		}
	}
}
int main()
{
	freopen("roundtable.in","r",stdin);
	freopen("roundtable.out","w",stdout);
	scanf("%d%d",&m,&n);
	for(int i=1;i<=m;i++)
	{
		scanf("%d",&M[i].M);
		M[i].now=i;
	}
	for(int i=1;i<=n;i++)
	{
		scanf("%d",&N[i].N);
		N[i].now=i;
	}
	sort(N+1,N+n+1);
	sort(M+1,M+m+1,tmpa);
	if(M[1].M>n)
	{
		printf("0");return 0;
	}
	for(int i=1;i<=m;i++)
	{
		fp(i);
		if(M[i].M!=0)
		{
			printf("0");return 0;
		}
	}
	sort(M+1,M+m+1,tmpb);
	printf("1\n");
	for(int i=1;i<=m;i++)
	{
		M[i].out();
	}
	return 0;
}