#include <bits/stdc++.h>
using namespace std;
#define int long long int
#define double long double
inline int power(int a, int b) {
int x = 1;
while (b) {
if (b & 1) x *= a;
a *= a;
b >>= 1;
}
return x;
}
const int M = 1000000007;
const int N = 3e5+9;
const int INF = 2e9+1;
const int LINF = 2000000000000000001;
//_ ***************************** START Below *******************************
vector<int> a;
//* O(n^2)
void consistency1(int n, int k1, int k2) {
int ans = 0;
for(int j=1; j<n-2; j++){
int i=0;
while(i<j){
if(a[i] + a[j] >= k1) break;
i++;
}
int leftCt = j-i;
int s= j+1, e = n-1;
int rightCt = 0;
while(s<e){
int sum = a[s] + a[e];
if(sum > k2){
rightCt += (e-s);
e--;
}
else{
s++;
}
}
ans += leftCt * rightCt;
}
cout << ans << endl;
}
//* O(n^2)
void consistency2(int n, int k1, int k2) {
int ans = 0;
vector<int> p(n);
for(int i=0; i<n-1; i++){
int target = k2 - a[i];
int j = lower_bound(a.begin() + i + 1, a.end(), target) - a.begin();
p[i] = n-j;
}
vector<int> rightSufix(n);
for(int i=n-2; i>=0; i--){
rightSufix[i] = rightSufix[i+1] + p[i];
}
for(int j=1; j<n-2; j++){
int target = k1 - a[j];
int i = lower_bound(a.begin(), a.begin()+j, target) - a.begin();
int leftCt = j-i;
int rightCt = rightSufix[j+1];
ans += leftCt * rightCt;
}
cout << ans << endl;
}
void solve() {
int n, k1, k2;
cin >> n >> k1 >> k2;
a.resize(n);
for(int i=0; i<n; i++) cin >> a[i];
consistency1(n, k1, k2);
consistency2(n, k1, k2);
}
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+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CiNkZWZpbmUgaW50ICAgICAgICAgICAgICBsb25nIGxvbmcgaW50CiNkZWZpbmUgZG91YmxlICAgICAgICAgICBsb25nIGRvdWJsZQppbmxpbmUgaW50IHBvd2VyKGludCBhLCBpbnQgYikgewogICAgaW50IHggPSAxOwogICAgd2hpbGUgKGIpIHsKICAgICAgICBpZiAoYiAmIDEpIHggKj0gYTsKICAgICAgICBhICo9IGE7CiAgICAgICAgYiA+Pj0gMTsKICAgIH0KICAgIHJldHVybiB4Owp9CgoKY29uc3QgaW50IE0gPSAxMDAwMDAwMDA3Owpjb25zdCBpbnQgTiA9IDNlNSs5Owpjb25zdCBpbnQgSU5GID0gMmU5KzE7CmNvbnN0IGludCBMSU5GID0gMjAwMDAwMDAwMDAwMDAwMDAwMTsKCi8vXyAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiBTVEFSVCBCZWxvdyAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCgoKCnZlY3RvcjxpbnQ+IGE7CgovLyogTyhuXjIpCnZvaWQgY29uc2lzdGVuY3kxKGludCBuLCBpbnQgazEsIGludCBrMikgewoJCglpbnQgYW5zID0gMDsKCWZvcihpbnQgaj0xOyBqPG4tMjsgaisrKXsKCQlpbnQgaT0wOwoJCXdoaWxlKGk8ail7CgkJCWlmKGFbaV0gKyBhW2pdID49IGsxKSBicmVhazsKCQkJaSsrOwoJCX0KCQlpbnQgbGVmdEN0ID0gai1pOwoJCQoJCWludCAgcz0gaisxLCBlID0gbi0xOwoJCWludCByaWdodEN0ID0gMDsKCQl3aGlsZShzPGUpewoJCQlpbnQgc3VtID0gYVtzXSArIGFbZV07CgkJCWlmKHN1bSA+IGsyKXsKCQkJCXJpZ2h0Q3QgKz0gKGUtcyk7CgkJCQllLS07CgkJCX0KCQkJZWxzZXsKCQkJCXMrKzsKCQkJfQoJCX0KCQlhbnMgKz0gbGVmdEN0ICogcmlnaHRDdDsKCX0KCQoJY291dCA8PCBhbnMgPDwgZW5kbDsKfQoKCgoKLy8qIE8obl4yKQp2b2lkIGNvbnNpc3RlbmN5MihpbnQgbiwgaW50IGsxLCBpbnQgazIpIHsKCQoJaW50IGFucyA9IDA7CgkKCXZlY3RvcjxpbnQ+IHAobik7Cglmb3IoaW50IGk9MDsgaTxuLTE7IGkrKyl7CgkJaW50IHRhcmdldCA9IGsyIC0gYVtpXTsKCQlpbnQgaiA9IGxvd2VyX2JvdW5kKGEuYmVnaW4oKSArIGkgKyAxLCBhLmVuZCgpLCB0YXJnZXQpIC0gYS5iZWdpbigpOwoJCXBbaV0gPSBuLWo7Cgl9Cgl2ZWN0b3I8aW50PiByaWdodFN1Zml4KG4pOwoJZm9yKGludCBpPW4tMjsgaT49MDsgaS0tKXsKCQlyaWdodFN1Zml4W2ldID0gcmlnaHRTdWZpeFtpKzFdICsgcFtpXTsKCX0KCQoJCglmb3IoaW50IGo9MTsgajxuLTI7IGorKyl7CgkJaW50IHRhcmdldCA9IGsxIC0gYVtqXTsKCQlpbnQgaSA9IGxvd2VyX2JvdW5kKGEuYmVnaW4oKSwgYS5iZWdpbigpK2osIHRhcmdldCkgLSBhLmJlZ2luKCk7CgkJaW50IGxlZnRDdCA9IGotaTsKCgkJaW50IHJpZ2h0Q3QgPSByaWdodFN1Zml4W2orMV07CgkJCgkJYW5zICs9IGxlZnRDdCAqIHJpZ2h0Q3Q7CgkJCgl9CgoKCWNvdXQgPDwgYW5zIDw8IGVuZGw7CgkKfQoKCnZvaWQgc29sdmUoKSB7CiAgICAKCWludCBuLCBrMSwgazI7CgljaW4gPj4gbiA+PiBrMSA+PiBrMjsKCQoJYS5yZXNpemUobik7Cglmb3IoaW50IGk9MDsgaTxuOyBpKyspIGNpbiA+PiBhW2ldOwogICAgCiAgICBjb25zaXN0ZW5jeTEobiwgazEsIGsyKTsKICAgIGNvbnNpc3RlbmN5MihuLCBrMSwgazIpOwoKfQoKCgoKCmludDMyX3QgbWFpbigpIHsKICAgIGlvc19iYXNlOjpzeW5jX3dpdGhfc3RkaW8oMCk7IGNpbi50aWUoMCk7IGNvdXQudGllKDApOwoKICAgIGludCB0ID0gMTsKICAgIC8vIGNpbiA+PiB0OwogICAgd2hpbGUgKHQtLSkgewogICAgICAgIHNvbHZlKCk7CiAgICB9CgogICAgcmV0dXJuIDA7Cn0=