#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;
int bruteforce(int n, int k1, int k2){
int ans = 0;
for(int i=0; i<n-2; i++){
for(int j=i+1; j<n-2; j++){
int leftSum = a[i] + a[j];
if(leftSum <= k1) continue;
for(int k=j+1; k<n-1; k++){
for(int l=k+1; l<n; l++){
int rightSum = a[k] + a[l];
if(rightSum > k2 ) ans++;
}
}
}
}
return ans;
}
int consistency1(int n, int k1, int k2) {
int ans = 0;
vector<int> pairsFrom(n);
for(int i=0; i<n-1; i++){
int j = upper_bound(a.begin()+i+1, a.end(), k2-a[i]) - a.begin();
pairsFrom[i] = n-j;
}
vector<int> sPairs(n+1);
for(int i=n-1; i>=0; i--){
sPairs[i] = sPairs[i+1] + pairsFrom[i];
}
int s = 0, e = n-3;
while(s<e){
if(a[s] + a[e] <= k1){
s++;
}
else{
int left = e-s;
int right = sPairs[e+1];
ans += (left * right);
e--;
}
}
return ans;
}
int consistency2(int n, int k1, int k2) {
int ans = 0;
vector<int> pairsFrom(n);
for(int i=0; i<n-1; i++){
int j = upper_bound(a.begin()+i+1, a.end(), k2-a[i]) - a.begin();
pairsFrom[i] = n-j;
}
vector<int> sPairs(n+1);
for(int i=n-1; i>=0; i--){
sPairs[i] = sPairs[i+1] + pairsFrom[i];
}
for(int j=1; j<n-2; j++){
int i = upper_bound(a.begin(), a.begin() + j, k1-a[j]) - a.begin();
int left= j-i;
int right = sPairs[j+1];
ans += left*right;
}
return ans;
}
int practice(int n, int k1, int k2) {
return 0;
}
void solve() {
int n, k1, k2;
cin >> n >> k1 >> k2;
a.resize(n);
for(int i=0; i<n; i++) cin >> a[i];
cout << bruteforce(n, k1, k2) << " -> ";
cout << consistency1(n, k1, k2) << " ";
cout << consistency2(n, k1, k2) << endl;
// cout << bruteforce(n, k1, k2) << " -> ";
// cout << practice(n, k1, k2) << 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+Pj0gMTsKICAgIH0KICAgIHJldHVybiB4Owp9CgoKLy9fICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqIFNUQVJUIEJlbG93ICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKCgoKdmVjdG9yPGludD4gYTsKCgppbnQgYnJ1dGVmb3JjZShpbnQgbiwgaW50IGsxLCBpbnQgazIpewoJaW50IGFucyA9IDA7CgkKCWZvcihpbnQgaT0wOyBpPG4tMjsgaSsrKXsKCQlmb3IoaW50IGo9aSsxOyBqPG4tMjsgaisrKXsKCQkJaW50IGxlZnRTdW0gPSBhW2ldICsgYVtqXTsKCQkJaWYobGVmdFN1bSA8PSBrMSkgY29udGludWU7CgkJCQoJCQlmb3IoaW50IGs9aisxOyBrPG4tMTsgaysrKXsKCQkJCWZvcihpbnQgbD1rKzE7IGw8bjsgbCsrKXsKCQkJCQlpbnQgcmlnaHRTdW0gPSBhW2tdICsgYVtsXTsKCQkJCQlpZihyaWdodFN1bSA+IGsyICkgYW5zKys7CgkJCQl9CgkJCX0KCQl9Cgl9CglyZXR1cm4gYW5zOwp9CgoKCgoKaW50IGNvbnNpc3RlbmN5MShpbnQgbiwgaW50IGsxLCBpbnQgazIpIHsKCQoJaW50IGFucyA9IDA7CgkKCXZlY3RvcjxpbnQ+IHBhaXJzRnJvbShuKTsKCWZvcihpbnQgaT0wOyBpPG4tMTsgaSsrKXsKCQlpbnQgaiA9IHVwcGVyX2JvdW5kKGEuYmVnaW4oKStpKzEsIGEuZW5kKCksIGsyLWFbaV0pIC0gYS5iZWdpbigpOwoJCQoJCXBhaXJzRnJvbVtpXSA9IG4tajsKCX0KCQoJdmVjdG9yPGludD4gc1BhaXJzKG4rMSk7Cglmb3IoaW50IGk9bi0xOyBpPj0wOyBpLS0pewoJCXNQYWlyc1tpXSA9IHNQYWlyc1tpKzFdICsgcGFpcnNGcm9tW2ldOwoJfQoJCgkKCWludCBzID0gMCwgZSA9IG4tMzsKCXdoaWxlKHM8ZSl7CgkJaWYoYVtzXSArIGFbZV0gPD0gazEpewoJCQlzKys7CgkJfQoJCWVsc2V7CgkJCWludCBsZWZ0ID0gZS1zOwoJCQlpbnQgcmlnaHQgPSBzUGFpcnNbZSsxXTsKCQkJCgkJCWFucyArPSAobGVmdCAqIHJpZ2h0KTsKCQkJCgkJCWUtLTsKCQl9Cgl9CgkKCXJldHVybiBhbnM7CgkKfQoKCgoKCgoKCmludCBjb25zaXN0ZW5jeTIoaW50IG4sIGludCBrMSwgaW50IGsyKSB7CgkKCWludCBhbnMgPSAwOwoKCXZlY3RvcjxpbnQ+IHBhaXJzRnJvbShuKTsKCWZvcihpbnQgaT0wOyBpPG4tMTsgaSsrKXsKCQlpbnQgaiA9IHVwcGVyX2JvdW5kKGEuYmVnaW4oKStpKzEsIGEuZW5kKCksIGsyLWFbaV0pIC0gYS5iZWdpbigpOwoJCQoJCXBhaXJzRnJvbVtpXSA9IG4tajsKCX0KCQoJdmVjdG9yPGludD4gc1BhaXJzKG4rMSk7Cglmb3IoaW50IGk9bi0xOyBpPj0wOyBpLS0pewoJCXNQYWlyc1tpXSA9IHNQYWlyc1tpKzFdICsgcGFpcnNGcm9tW2ldOwoJfQoKCWZvcihpbnQgaj0xOyBqPG4tMjsgaisrKXsKCQlpbnQgaSA9IHVwcGVyX2JvdW5kKGEuYmVnaW4oKSwgYS5iZWdpbigpICsgaiwgazEtYVtqXSkgLSBhLmJlZ2luKCk7CgkJaW50IGxlZnQ9IGotaTsKCQkKCQlpbnQgcmlnaHQgPSBzUGFpcnNbaisxXTsKCQkKCQlhbnMgKz0gbGVmdCpyaWdodDsKCX0KCglyZXR1cm4gYW5zOwp9CgoKCgoKCgoKCgoKCgoKCgoKCgppbnQgcHJhY3RpY2UoaW50IG4sIGludCBrMSwgaW50IGsyKSB7CgkKCXJldHVybiAwOwoJCn0KCgoKCgoKdm9pZCBzb2x2ZSgpIHsKICAgIAoJaW50IG4sIGsxLCBrMjsKCWNpbiA+PiBuID4+IGsxID4+IGsyOwoJCglhLnJlc2l6ZShuKTsKCWZvcihpbnQgaT0wOyBpPG47IGkrKykgY2luID4+IGFbaV07CiAgICAKICAgIGNvdXQgPDwgYnJ1dGVmb3JjZShuLCBrMSwgazIpIDw8ICIgLT4gIjsKICAgIGNvdXQgPDwgY29uc2lzdGVuY3kxKG4sIGsxLCBrMikgPDwgIiAiOwogICAgY291dCA8PCBjb25zaXN0ZW5jeTIobiwgazEsIGsyKSA8PCBlbmRsOwogICAgCiAgICAKICAgIC8vIGNvdXQgPDwgYnJ1dGVmb3JjZShuLCBrMSwgazIpIDw8ICIgLT4gIjsKICAgIC8vIGNvdXQgPDwgcHJhY3RpY2UobiwgazEsIGsyKSA8PCBlbmRsOwogICAgCn0KCgoKCgppbnQzMl90IG1haW4oKSB7CiAgICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKDApOyBjaW4udGllKDApOyBjb3V0LnRpZSgwKTsKCiAgICBpbnQgdCA9IDE7CiAgICBjaW4gPj4gdDsKICAgIHdoaWxlICh0LS0pIHsKICAgICAgICBzb2x2ZSgpOwogICAgfQoKICAgIHJldHVybiAwOwp9