社区讨论
求助 30pts 部分分 dfs
P1048[NOIP 2005 普及组] 采药参与者 6已保存回复 6
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 6 条
- 当前快照
- 1 份
- 快照标识符
- @lo1upq4e
- 此快照首次捕获于
- 2023/10/23 03:17 2 年前
- 此快照最后确认于
- 2023/11/03 03:49 2 年前
样例过了 哪里有问题啊
CPP#include<bits/stdc++.h>
#define ll long long
#define tim first
#define val second
using namespace std;
const int N=101;
int t,m,ans,sum,cnt;
array<pair<int,int>,N> a;
array<bool,N> vis;
void dfs(int pos)
{
if(pos==m+1)
{
for(int i=1;i<=m;i++)
{
if(vis[i]==1) sum+=a[i].val;
}
if(cnt<=t) ans=max(ans,sum);
return;
}
else
{
for(int i=0;i<=1;i++)
{
vis[pos]=i;
cnt+=i*a[pos].tim;
dfs(pos+1);
}
}
}
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin>>t>>m;
for(int i=1;i<=m;i++) cin>>a[i].tim>>a[i].val;
dfs(1);
cout<<ans;
return 0;
}
回复
共 6 条回复,欢迎继续交流。
正在加载回复...