#include <iostream> #include <vector> #include <bitset> #include <iomanip> using namespace std; #define For(i, a, b) for(int i = (a); i < (b); i++) #define rep(i, n) For(i, 0, n) #define rFor(i, a, b) for(int i = (a); i >= (b); i--) #define ALL(v) (v).begin(), (v).end() #define rALL(v) (v).rbegin(), (v).rend() using lint = long long; using ld = long double; int INF = 2000000000; lint LINF = 1000000000000000000; struct SetupIo { SetupIo() { ios::sync_with_stdio(false); cin.tie(nullptr); cout << fixed << setprecision(15); } } setupio; int main() { int n, f; cin >> n >> f; vector<int> a(n), b(n), c(n); for (int &x : a) { cin >> x; } for (int &x : b) { cin >> x; } for (int &x : c) { cin >> x; } bitset<900010> dp; dp[0] = 1; rep(i, n) { dp = (dp << a[i]) | (dp << b[i]) | (dp << c[i]); cout << dp.count() << "\n"; } }