#include #define L long long #define M 100005 using namespace std; struct node{ int a,b; friend bool operator <(node A,node B){ bool typeA=(A.atypeB; if(typeA) return A.aB.b; } void rd(){scanf("%d%d",&a,&b);} }p[M]; int Main(){ L n,k; cin>>n>>k; for(int i=1;i<=n;i++) p[i].rd(); sort(p+1,p+n+1); for(int i=1;i<=n;i++){ k-=p[i].a; if(k<1) {printf("NO\n"); return 0;} k+=p[i].b; } printf("YES\n"); return 0; } int main(){ // freopen("tower.in","r",stdin); // freopen("tower.out","w",stdout); int T; cin>>T; while(T--) Main(); }