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;
}

Comments