#include <bits/stdc++.h> #define ll long long int #define ld long double using namespace std; void mainSolve() { ll n, x; cin >> n >> x; vector<ll> v(n); for (int i = 0; i < n; i++) cin >> v[i]; set<ll> s; s.insert(v[n - 1]); for (int i = n - 2; i >= 0; i--) { ll sum = 0; if ((*s.rbegin()) < v[i]) { sum = v[i] + (*s.rbegin()); } else if ((*s.begin()) < v[i]) { auto it = s.lower_bound(v[i]); it--; sum = v[i] + (*it); } if (sum > x) { cout << "NO\n"; return; } s.insert(v[i]); } cout << "YES\n"; } int main() { #ifndef ONLINE_JUDGE freopen("input.txt", "r", stdin); freopen("output.txt", "w", stdout); #endif int t; cin >> t; while (t--) { mainSolve(); } return 0; }