2
#include<stdio.h> #include<math.h> #include<stdlib.h> #include<string.h> struct node { int xi,ri; }ps[10000]; int cmp(const void *a,const void *b) { return *(int*)b-*(int*)a; } int xi,ri; int ps[20000],a[10000]; int main() { int m,n,w,h,temp,j=0; scanf("%d",&m); while(m--){ scanf("%d%d%d",&n,&w,*h); memset(ps,0,2n); memset(a,0,n); for(int i=0;i<n;i++){ scanf("%d%d",&xi,&ri); if(ri<=h/2.0) continue; temp=sqrt(ri*ri-h*h/4.0); a[i]=temp; ps[j]=xi-temp; ps[j++]=xi+temp; } if(ps[0]>0||ps[j]-w<0) {printf("0\n"); continue;} qsort(a,n,sizeof(a[0]),cmp); for(j=0;j<n;j++){ w-= if(2*a[0]>=w) {count++;break;} } printf("%d\n",j); } return 0; }