#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);
int s = 0, e = n-1;
while(s<e){
if(a[s] + a[e] > k2){
e--;
}
else{
pairsFrom[s] = n-e-1;
s++;
}
}
while(s<n){
pairsFrom[s] = n-s-1;
s++;
}
vector<int> sPairs(n+1);
for(int i=n-1; i>=0; i--){
sPairs[i] = sPairs[i+1] + pairsFrom[i];
}
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> pairsEndingAt(n);
int s = 0, e = n-1;
while(s<e){
if(a[s] + a[e] <= k1){
s++;
}
else{
pairsEndingAt[e] = e-s;
e--;
}
}
vector<int> pairsFrom(n);
s = 0, e = n-1;
while(s<e){
if(a[s] + a[e] > k2){
e--;
}
else{
pairsFrom[s] = n-e-1;
s++;
}
}
while(s<n){
pairsFrom[s] = n-s-1;
s++;
}
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 left= pairsEndingAt[j];
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+IHBhaXJzRnJvbShuKTsKCWludCBzID0gMCwgZSA9IG4tMTsKCXdoaWxlKHM8ZSl7CgkJaWYoYVtzXSArIGFbZV0gPiBrMil7CgkJCWUtLTsKCQl9CgkJZWxzZXsKCQkJcGFpcnNGcm9tW3NdID0gbi1lLTE7CgkJCXMrKzsKCQl9Cgl9Cgl3aGlsZShzPG4pewoJCXBhaXJzRnJvbVtzXSA9IG4tcy0xOwoJCXMrKzsKCX0KCQoJdmVjdG9yPGludD4gc1BhaXJzKG4rMSk7Cglmb3IoaW50IGk9bi0xOyBpPj0wOyBpLS0pewoJCXNQYWlyc1tpXSA9IHNQYWlyc1tpKzFdICsgcGFpcnNGcm9tW2ldOwoJfQoJCgkKCXMgPSAwLCBlID0gbi0zOwoJd2hpbGUoczxlKXsKCQlpZihhW3NdICsgYVtlXSA8PSBrMSl7CgkJCXMrKzsKCQl9CgkJZWxzZXsKCQkJaW50IGxlZnQgPSBlLXM7CgkJCWludCByaWdodCA9IHNQYWlyc1tlKzFdOwoJCQkKCQkJYW5zICs9IChsZWZ0ICogcmlnaHQpOwoJCQkKCQkJZS0tOwoJCX0KCX0KCQoJcmV0dXJuIGFuczsKCQp9CgoKCgoKCgoKaW50IGNvbnNpc3RlbmN5MihpbnQgbiwgaW50IGsxLCBpbnQgazIpIHsKCQoJaW50IGFucyA9IDA7CgkKCQoJdmVjdG9yPGludD4gcGFpcnNFbmRpbmdBdChuKTsKCWludCBzID0gMCwgZSA9IG4tMTsKCXdoaWxlKHM8ZSl7CgkJaWYoYVtzXSArIGFbZV0gPD0gazEpewoJCQlzKys7CgkJfQoJCWVsc2V7CgkJCXBhaXJzRW5kaW5nQXRbZV0gPSBlLXM7CgkJCWUtLTsKCQl9Cgl9CgkKCQoKCXZlY3RvcjxpbnQ+IHBhaXJzRnJvbShuKTsKCXMgPSAwLCBlID0gbi0xOwoJd2hpbGUoczxlKXsKCQlpZihhW3NdICsgYVtlXSA+IGsyKXsKCQkJZS0tOwoJCX0KCQllbHNlewoJCQlwYWlyc0Zyb21bc10gPSBuLWUtMTsKCQkJcysrOwoJCX0KCX0KCXdoaWxlKHM8bil7CgkJcGFpcnNGcm9tW3NdID0gbi1zLTE7CgkJcysrOwoJfQoJCgl2ZWN0b3I8aW50PiBzUGFpcnMobisxKTsKCWZvcihpbnQgaT1uLTE7IGk+PTA7IGktLSl7CgkJc1BhaXJzW2ldID0gc1BhaXJzW2krMV0gKyBwYWlyc0Zyb21baV07Cgl9CgkKCQoKCWZvcihpbnQgaj0xOyBqPG4tMjsgaisrKXsKCgkJaW50IGxlZnQ9IHBhaXJzRW5kaW5nQXRbal07CgkJCgkJaW50IHJpZ2h0ID0gc1BhaXJzW2orMV07CgkJCgkJYW5zICs9IGxlZnQqcmlnaHQ7Cgl9CgoJcmV0dXJuIGFuczsKfQoKCgoKCgoKCgoKCgoKCgoKCgoKaW50IHByYWN0aWNlKGludCBuLCBpbnQgazEsIGludCBrMikgewoJCglyZXR1cm4gMDsKCQp9CgoKCgoKCnZvaWQgc29sdmUoKSB7CiAgICAKCWludCBuLCBrMSwgazI7CgljaW4gPj4gbiA+PiBrMSA+PiBrMjsKCQoJYS5yZXNpemUobik7Cglmb3IoaW50IGk9MDsgaTxuOyBpKyspIGNpbiA+PiBhW2ldOwogICAgCiAgICBjb3V0IDw8IGJydXRlZm9yY2UobiwgazEsIGsyKSA8PCAiIC0+ICI7CiAgICBjb3V0IDw8IGNvbnNpc3RlbmN5MShuLCBrMSwgazIpIDw8ICIgIjsKICAgIGNvdXQgPDwgY29uc2lzdGVuY3kyKG4sIGsxLCBrMikgPDwgZW5kbDsKICAgIAogICAgCiAgICAvLyBjb3V0IDw8IGJydXRlZm9yY2UobiwgazEsIGsyKSA8PCAiIC0+ICI7CiAgICAvLyBjb3V0IDw8IHByYWN0aWNlKG4sIGsxLCBrMikgPDwgZW5kbDsKICAgIAp9CgoKCgoKaW50MzJfdCBtYWluKCkgewogICAgaW9zX2Jhc2U6OnN5bmNfd2l0aF9zdGRpbygwKTsgY2luLnRpZSgwKTsgY291dC50aWUoMCk7CgogICAgaW50IHQgPSAxOwogICAgY2luID4+IHQ7CiAgICB3aGlsZSAodC0tKSB7CiAgICAgICAgc29sdmUoKTsKICAgIH0KCiAgICByZXR1cm4gMDsKfQ==