社区讨论
求调dfs
P1048[NOIP 2005 普及组] 采药参与者 2已保存回复 2
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 2 条
- 当前快照
- 1 份
- 快照标识符
- @lzky9vfp
- 此快照首次捕获于
- 2024/08/08 15:21 2 年前
- 此快照最后确认于
- 2024/08/08 15:55 2 年前
CPP
#include<bits/stdc++.h>
using namespace std;
long long a[100],b[100],c,n,m;
void dfs(long long q,long long x,long long y,long long o){//q为容量//x为价值//y为当前//o为选择
if(y==m)
return;
if(q-a[y]<0&&x>c&&o==1){
c=x;
dfs(q,x,y+1,1);
dfs(q,x,y+1,0);
}
else
if(o==1){
dfs(q-a[y],x+b[y],y+1,1);
dfs(q-a[y],x+b[y],y+1,0);
}else{
dfs(q,x,y+1,1);
dfs(q,x,y+1,0);
}
return;
}
int main(){
//freopen("knapsack.in","r",stdin);
//freopen("knapsack.out","w",stdout);
cin>>n>>m;
for(int i=1;i<=m;i++)
cin>>a[i]>>b[i];
dfs(n,0,1,0);
dfs(n,0,1,1);
cout<<c;
return 0;
}
回复
共 2 条回复,欢迎继续交流。
正在加载回复...