#include<iostream>
#include<algorithm>
const int N = 1e5 + 10;
int a[N], b[N], c[N];
long long ans;
#define ll long long
using namespace std;
int main()
{
int n;
cin >> n;
for (int i = 1; i <= n; i++)
scanf("%d", &a[i]);
for (int i = 1; i <= n; i++)
scanf("%d", &b[i]);
for (int i = 1; i <= n; i++)
scanf("%d", &c[i]);
sort(a + 1, a + n + 1);
sort(b + 1, b + n + 1);
sort(c + 1, c + n + 1);
for (int i = 1; i <= n; i++)
{
int l = 0, r = n+1;
while (l < r)
{
int mid = (l + r) / 2;
if (a[mid] >= b[i])r= mid;
else
l = mid+1;
}
if (l>0)//找到了第一个大于等于b[i]的下标为l
{
ll j = l - 1;
int l = 0, r = n+1;
while (l < r)//找最后个小于等于b[i]的下标为l
{
int mid = (l + r + 1) / 2;
if (c[mid] <= b[i])l = mid;
else
r = mid - 1;
}
ll k;
if (r<n+1)
{
k = n - r;
ans += k * j;
}
}
}
cout<<ans<<endl;
}
stl
#include<iostream>
#include<algorithm>
#define _CRT_SECURE_NO_WARNINGS
const int N = 1e5 + 10;
int a[N], b[N], c[N];
long long ans;
#define ll long long
using namespace std;
int main()
{
int n;
cin >> n;
for (int i = 1; i <= n; i++)
cin >> a[i];
for (int i = 1; i <= n; i++)
cin >> b[i];
for (int i = 1; i <= n; i++)
cin >> c[i];
sort(a + 1, a + n + 1);
sort(b + 1, b + n + 1);
sort(c + 1, c + n + 1);
for (int i = 1; i <= n; i++)
{
ll x = (long long)(bound(a + 1, a + 1 + n, b[i])-a)-1;//第一个大于等于某个数的下标
ll y = (long long)n - (upper_bound(c + 1, c + 1 + n, b[i])-c) + 1;
ans += x * y;
}
cout << ans << endl;
return 0;
}