LS艾子轩 edited 1 月,4 周前
#include <bits/stdc++.h>
using namespace std;
int n,m;
struct gy{
int a,b;
double c;
}p[10005];
bool cmp(gy x,gy y){
if(x.b==y.b){
return x.a<y.a;
}
return x.b>y.b;
}
int main (){
scanf("%d %d",&n,&m);
for(int i=1;i<=n;i++){
scanf("%d %d",&p[i].a,&p[i].b);
}
sort(p+1,p+n+1,cmp);
while(m--){
int w,g=0;
scanf("%d",&w);
for(int i=1;i<=n;i++)
if(w>=p[i].a){
w-=p[i].a;
g+=p[i].b;
}
cout<<g<<endl;
}
return 0;
}