社区讨论
ABC F WA 求条
学术版参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @mkif2d7l
- 此快照首次捕获于
- 2026/01/17 22:42 上个月
- 此快照最后确认于
- 2026/01/17 22:47 上个月
思路是前后缀背包,记录后缀背包的前缀 max,枚举 i,计算出不选 i 和选择 i 的最优答案,与全局的比较,why WA?
CPP#include<bits/stdc++.h>
using namespace std;
const int N=1e3+10,M=5e4+10;
typedef long long ll;
int n,m,p[N],v[N];ll ans,dp1[N][M],dp2[N][M];
char c[N];
int main() {
ios::sync_with_stdio(0);
cin.tie(0),cout.tie(0);
cin>>n>>m;
for(int i=1;i<=n;i++){
cin>>p[i]>>v[i];
}
for(int i=1;i<=n;i++){
for(int j=m;j>=p[i];j--){
dp1[i][j]=max(dp1[i-1][j],dp1[i-1][j-p[i]]+v[i]);
}
}
for(int j=m;j>=0;j--)ans=max(ans,dp1[n][j]);
for(int i=n;i>=1;i--){
for(int j=m;j>=p[i];j--){
dp2[i][j]=max(dp2[i+1][j],dp2[i+1][j-p[i]]+v[i]);
}
}
for(int i=1;i<=n;i++){
for(int j=0;j<=m;j++){
dp2[i][j]=max(dp2[i][j-1],dp2[i][j]);
}
}
for(int i=1;i<=n;i++){
ll noi=0;
for(int j=0;j<=m;j++){
noi=max(noi,dp1[i-1][j]+dp2[i+1][m-j]);
}
ll havi=0;
for(int j=0;j<=m-p[i];j++){
havi=max(havi,dp1[i-1][j]+dp2[i+1][m-p[i]-j]+v[i]);
}
if(noi<ans){
c[i-1]='A';
}
else if(havi<ans){
c[i-1]='C';
}
else c[i-1]='B';
}
cout<<c;
return 0;
}
回复
共 0 条回复,欢迎继续交流。
正在加载回复...