#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int INF=0x3f3f3f3f;
const ll LLINF=0x3f3f3f3f3f3f3f3fLL;
const int mod=998244353;
const int MAX=1.5e4+10;
const int N=9e5;
int a[MAX],b[MAX],c[MAX];
int main()
{
	int n,f,i;
	scanf("%d%d",&n,&f);
	for(i=1;i<=n;i++) scanf("%d",&a[i]);
	for(i=1;i<=n;i++) scanf("%d",&b[i]);
	for(i=1;i<=n;i++) scanf("%d",&c[i]);
	bitset<N> dp,tmp;
	dp[a[1]]=1;
	dp[b[1]]=1;
	dp[c[1]]=1;
	printf("%d\n",dp.count());
	for(i=2;i<=n;i++)
	{
		tmp=dp;
		dp|=(tmp<<a[i]);
		dp|=(tmp<<b[i]);
		dp|=(tmp<<c[i]);
		printf("%d\n",dp.count());
	}
	return 0;
}