#define _CRT_SECURE_NO_WARNINGS #define _SILENCE_CXX17_C_HEADER_DEPRECATION_WARNING #include using namespace std; #define CRP(t, x) const t &x #define OPL(t, x) bool operator<(CRP(t, x)) const #define FIL(x, v) memset(x, v, sizeof(x)) #define CLR(x) FIL(x, 0) #define NE1(x) FIL(x, -1) #define INF(x) FIL(x, 0x3f) #ifndef _DEBUG #define _DEBUG 0 #endif // !_DEBUG #define IFD if (_DEBUG) typedef long long ll, i64; const int N = 1e6 + 60; int h[N]; int main() { int T, n, m, k; scanf("%d", &T); while (T--) { scanf("%d%d%d", &n, &m, &k); for (int i = 0; i < n; i++) scanf("%d", h + i); bool flag = true; for (int i = 0; i < n - 1; i++) { int target = max(0, h[i + 1] - k); if (h[i] + m < target) { flag = false; break; } m += h[i] - target; } puts(flag ? "YES" : "NO"); } return 0; }