#include <bits/stdc++.h>
using namespace std;
#define int long long int
#define double long double
#define print(a) for(auto x : a) cout << x << " "; cout << endl
const int M = 1000000007;
const int N = 3e5+9;
const int INF = 2e9+1;
const int LINF = 2000000000000000001;
inline int power(int a, int b, int mod=M) {
int x = 1;
a %= mod;
while (b) {
if (b & 1) x = (x * a) % mod;
a = (a * a) % mod;
b >>= 1;
}
return x;
}
//_ ***************************** START Below *******************************
vector<int> a, b, c, d;
//* Hashing + 2 Ptr => O(n^3)
int consistency1(int n){
sort(begin(c), end(c));
sort(begin(d), end(d));
int ans = 0;
for(int i=0; i<n; i++){
for(int j=0; j<n; j++){
int sum = a[i]+b[j];
int ct = 0;
int s = 0, e = n-1;
while(s<n && e>=0){
if(c[s] + d[e] == -sum ){
int x = c[s];
int f1 = 0;
while(s<n && c[s] == x){
f1++;
s++;
}
int y = d[e];
int f2 = 0;
while(e>=0 && d[e] == y){
f2++;
e--;
}
ct += f1*f2;
}
else if(c[s] + d[e] > -sum){
e--;
}
else{
s++;
}
}
ans += ct;
}
}
return ans;
}
//* Optimization :
//* Fetch all possible sum in map : SC = O(n^2)
//* max distinct sum in map == O(n^2) , TC == O(n^2 * n) == O(n^3)
int consistency2(int n){
sort(begin(c), end(c));
sort(begin(d), end(d));
unordered_map<int,int> mp;
for(int i=0; i<n; i++){
for(int j=0; j<n; j++){
int sum = a[i]+b[j];
mp[sum]++;
}
}
int ans = 0;
for(auto& t : mp){
int sum = t.first;
int f = t.second;
int ct = 0;
int s = 0, e = n-1;
while(s<n && e>=0){
if(c[s] + d[e] == -sum ){
int x = c[s];
int f1 = 0;
while(s<n && c[s] == x){
f1++;
s++;
}
int y = d[e];
int f2 = 0;
while(e>=0 && d[e] == y){
f2++;
e--;
}
ct += f1*f2;
}
else if(c[s] + d[e] > -sum){
e--;
}
else{
s++;
}
}
ans += f*ct;
}
return ans;
}
//* Hashmap
int consistency3(int n){
unordered_map<int,int> mp;
for(int i=0; i<n; i++){
for(int j=0; j<n; j++){
int sum = a[i]+b[j];
mp[sum]++;
}
}
int ans = 0;
for(int i=0; i<n; i++){
for(int j=0; j<n; j++){
int sum = c[i]+d[j];
if(mp.count(-sum)) ans += mp[-sum];
}
}
return ans;
}
int practice(int n){
return 0;
}
void solve() {
int n;
cin>> n;
a.resize(n);
b.resize(n);
c.resize(n);
d.resize(n);
for(int i=0; i<n; i++) cin >> a[i];
for(int i=0; i<n; i++) cin >> b[i];
for(int i=0; i<n; i++) cin >> c[i];
for(int i=0; i<n; i++) cin >> d[i];
cout << consistency1(n) << " " << consistency2(n) << " " << consistency3(n) << endl;
}
int32_t main() {
ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
int t = 1;
// cin >> t;
while (t--) {
solve();
}
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CiNkZWZpbmUgaW50ICAgICAgICAgICAgICBsb25nIGxvbmcgaW50CiNkZWZpbmUgZG91YmxlICAgICAgICAgICBsb25nIGRvdWJsZQojZGVmaW5lIHByaW50KGEpICAgICAgICAgZm9yKGF1dG8geCA6IGEpIGNvdXQgPDwgeCA8PCAiICI7IGNvdXQgPDwgZW5kbAoKCmNvbnN0IGludCBNID0gMTAwMDAwMDAwNzsKY29uc3QgaW50IE4gPSAzZTUrOTsKY29uc3QgaW50IElORiA9IDJlOSsxOwpjb25zdCBpbnQgTElORiA9IDIwMDAwMDAwMDAwMDAwMDAwMDE7CgppbmxpbmUgaW50IHBvd2VyKGludCBhLCBpbnQgYiwgaW50IG1vZD1NKSB7CiAgICBpbnQgeCA9IDE7CiAgICBhICU9IG1vZDsKICAgIHdoaWxlIChiKSB7CiAgICAgICAgaWYgKGIgJiAxKSB4ID0gKHggKiBhKSAlIG1vZDsgCiAgICAgICAgYSA9IChhICogYSkgJSBtb2Q7CiAgICAgICAgYiA+Pj0gMTsKICAgIH0KICAgIHJldHVybiB4Owp9CgoKLy9fICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqIFNUQVJUIEJlbG93ICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKCgoKCnZlY3RvcjxpbnQ+IGEsIGIsIGMsIGQ7CgovLyogSGFzaGluZyArIDIgUHRyICAgID0+ICAgICBPKG5eMykKaW50IGNvbnNpc3RlbmN5MShpbnQgbil7CgkKCXNvcnQoYmVnaW4oYyksIGVuZChjKSk7CiAgICBzb3J0KGJlZ2luKGQpLCBlbmQoZCkpOwogICAgCiAgICBpbnQgYW5zID0gMDsKICAgIGZvcihpbnQgaT0wOyBpPG47IGkrKyl7CiAgICAgICAgZm9yKGludCBqPTA7IGo8bjsgaisrKXsKICAgICAgICAgICAgaW50IHN1bSA9IGFbaV0rYltqXTsKICAgICAgICAgICAgCiAgICAgICAgICAgIGludCBjdCA9IDA7CiAgICAgICAgICAgIGludCBzID0gMCwgZSA9IG4tMTsKICAgICAgICAgICAgCiAgICAgICAgICAgIHdoaWxlKHM8biAmJiBlPj0wKXsKICAgICAgICAgICAgICAgIGlmKGNbc10gKyBkW2VdID09IC1zdW0gKXsKICAgICAgICAgICAgICAgICAgICBpbnQgeCA9IGNbc107CiAgICAgICAgICAgICAgICAgICAgaW50IGYxID0gMDsKICAgICAgICAgICAgICAgICAgICB3aGlsZShzPG4gJiYgY1tzXSA9PSB4KXsKICAgICAgICAgICAgICAgICAgICAgICAgZjErKzsKICAgICAgICAgICAgICAgICAgICAgICAgcysrOwogICAgICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICBpbnQgeSA9IGRbZV07CiAgICAgICAgICAgICAgICAgICAgaW50IGYyID0gMDsKICAgICAgICAgICAgICAgICAgICB3aGlsZShlPj0wICYmIGRbZV0gPT0geSl7CiAgICAgICAgICAgICAgICAgICAgICAgIGYyKys7CiAgICAgICAgICAgICAgICAgICAgICAgIGUtLTsKICAgICAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgY3QgKz0gZjEqZjI7CiAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgICAgICBlbHNlIGlmKGNbc10gKyBkW2VdID4gLXN1bSl7CiAgICAgICAgICAgICAgICAgICAgZS0tOwogICAgICAgICAgICAgICAgfQogICAgICAgICAgICAgICAgZWxzZXsKICAgICAgICAgICAgICAgICAgICBzKys7CiAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgIH0KICAgICAgICAgICAgYW5zICs9IGN0OwogICAgICAgIH0KICAgIH0KICAgIAogICAgcmV0dXJuIGFuczsKfQoKCgovLyogT3B0aW1pemF0aW9uIDogCi8vKiBGZXRjaCBhbGwgcG9zc2libGUgc3VtIGluIG1hcCA6IFNDID0gTyhuXjIpCi8vKiAJbWF4IGRpc3RpbmN0IHN1bSBpbiBtYXAgPT0gTyhuXjIpICwgVEMgPT0gTyhuXjIgKiBuKSA9PSBPKG5eMykKCmludCBjb25zaXN0ZW5jeTIoaW50IG4pewoJCglzb3J0KGJlZ2luKGMpLCBlbmQoYykpOwoJc29ydChiZWdpbihkKSwgZW5kKGQpKTsKCQoJdW5vcmRlcmVkX21hcDxpbnQsaW50PiBtcDsKCWZvcihpbnQgaT0wOyBpPG47IGkrKyl7CgkgICAgZm9yKGludCBqPTA7IGo8bjsgaisrKXsKCSAgICAgICAgaW50IHN1bSA9IGFbaV0rYltqXTsKCSAgICAgICAgbXBbc3VtXSsrOwoJICAgIH0KCX0KCQoJaW50IGFucyA9IDA7Cglmb3IoYXV0byYgdCA6IG1wKXsKCSAgICBpbnQgc3VtID0gdC5maXJzdDsKCSAgICBpbnQgZiA9IHQuc2Vjb25kOwoJICAgIGludCBjdCA9IDA7CgkgICAgaW50IHMgPSAwLCBlID0gbi0xOwoJICAgIHdoaWxlKHM8biAmJiBlPj0wKXsKCSAgICAgICAgaWYoY1tzXSArIGRbZV0gPT0gLXN1bSApewoJICAgICAgICAJCgkgICAgICAgICAgICBpbnQgeCA9IGNbc107CgkgICAgICAgICAgICBpbnQgZjEgPSAwOwoJICAgICAgICAgICAgd2hpbGUoczxuICYmIGNbc10gPT0geCl7CgkgICAgICAgICAgICAgICAgZjErKzsKCSAgICAgICAgICAgICAgICBzKys7CgkgICAgICAgICAgICB9CgkgICAgICAgICAgICAKCSAgICAgICAgICAgIGludCB5ID0gZFtlXTsKCSAgICAgICAgICAgIGludCBmMiA9IDA7CgkgICAgICAgICAgICB3aGlsZShlPj0wICYmIGRbZV0gPT0geSl7CgkgICAgICAgICAgICAgICAgZjIrKzsKCSAgICAgICAgICAgICAgICBlLS07CgkgICAgICAgICAgICB9CgkgICAgICAgICAgICAKCSAgICAgICAgICAgIGN0ICs9IGYxKmYyOwoJICAgICAgICB9CgkgICAgICAgIGVsc2UgaWYoY1tzXSArIGRbZV0gPiAtc3VtKXsKCSAgICAgICAgICAgIGUtLTsKCSAgICAgICAgfQoJICAgICAgICBlbHNlewoJICAgICAgICAgICAgcysrOwoJICAgICAgICB9CgkgICAgfQoJICAgIGFucyArPSBmKmN0OwoJfQoJcmV0dXJuIGFuczsKfQoKCgovLyogSGFzaG1hcAoKaW50IGNvbnNpc3RlbmN5MyhpbnQgbil7CgogICAgdW5vcmRlcmVkX21hcDxpbnQsaW50PiBtcDsKICAgIGZvcihpbnQgaT0wOyBpPG47IGkrKyl7CiAgICAgICAgZm9yKGludCBqPTA7IGo8bjsgaisrKXsKICAgICAgICAgICAgaW50IHN1bSA9IGFbaV0rYltqXTsKICAgICAgICAgICAgbXBbc3VtXSsrOwogICAgICAgIH0KICAgIH0KICAgIAogICAgaW50IGFucyA9IDA7CiAgICBmb3IoaW50IGk9MDsgaTxuOyBpKyspewogICAgICAgIGZvcihpbnQgaj0wOyBqPG47IGorKyl7CiAgICAgICAgICAgIGludCBzdW0gPSBjW2ldK2Rbal07CiAgICAgICAgICAgIAogICAgICAgICAgICBpZihtcC5jb3VudCgtc3VtKSkgYW5zICs9IG1wWy1zdW1dOwogICAgICAgIH0KICAgIH0KICAgIHJldHVybiBhbnM7CgkKfQoKCgoKCgoKCgoKCgppbnQgcHJhY3RpY2UoaW50IG4pewoKCiAgICByZXR1cm4gMDsKfQoKCgoKCnZvaWQgc29sdmUoKSB7CiAgICAKICAgIGludCBuOwogICAgY2luPj4gbjsKICAgIAogICAgYS5yZXNpemUobik7CiAgICBiLnJlc2l6ZShuKTsKICAgIGMucmVzaXplKG4pOwogICAgZC5yZXNpemUobik7CiAgICBmb3IoaW50IGk9MDsgaTxuOyBpKyspIGNpbiA+PiBhW2ldOwogICAgZm9yKGludCBpPTA7IGk8bjsgaSsrKSBjaW4gPj4gYltpXTsKICAgIGZvcihpbnQgaT0wOyBpPG47IGkrKykgY2luID4+IGNbaV07CiAgICBmb3IoaW50IGk9MDsgaTxuOyBpKyspIGNpbiA+PiBkW2ldOwogICAgCiAgICBjb3V0IDw8IGNvbnNpc3RlbmN5MShuKSA8PCAgIiAiIDw8IGNvbnNpc3RlbmN5MihuKSA8PCAiICIgPDwgY29uc2lzdGVuY3kzKG4pIDw8IGVuZGw7CgoKfQoKCgoKCmludDMyX3QgbWFpbigpIHsKICAgIGlvc19iYXNlOjpzeW5jX3dpdGhfc3RkaW8oMCk7IGNpbi50aWUoMCk7IGNvdXQudGllKDApOwoKICAgIGludCB0ID0gMTsKICAgIC8vIGNpbiA+PiB0OwogICAgd2hpbGUgKHQtLSkgewogICAgICAgIHNvbHZlKCk7CiAgICB9CgogICAgcmV0dXJuIDA7Cn0=