dfs做法1AC,其他全WA
查看原帖
dfs做法1AC,其他全WA
326713
suyunqiaoKID楼主2020/9/19 15:44
#include<bits/stdc++.h>
using namespace std;
const long long MAXN=1000001;
struct dp{
	int v;
	int p;
}a[MAXN];
int bag,n,ans;
void dfs(int x,int y,int z){
	if(z>n){
		ans=max(ans,x);
		return;
	}
	if(y>=bag)
	return;
	ans=max(ans,x);
	dfs(x,y,z+1);
	dfs(x+a[z].p,y+a[z].v,z+1);
}
int main(){
	ios::sync_with_stdio(false);
	cin>>bag>>n;
	for(register int i=1;i<=n;i++){
		cin>>a[i].v>>a[i].p;
		a[i].p*=a[i].v;
	}
	dfs(0,0,0);
	cout<<ans<<endl;
}

求dalao解答

2020/9/19 15:44
加载中...