USACO 2003 Fall Orange Cow Exhibition /// 負數01背包 oj22829
阿新 • • 發佈:2018-05-23
-i code src clu ans open mes d+ sed
題目大意:
輸入n
接下來n行 每行輸入 a b
輸出n行中 a+b總和最大的同時滿足 所有a總和>=0所有b總和>=0的值
負數的01背包應該反過來
w[i]為正數時 需要從大往小推 即往0推
w[i]為負數時 同樣應該往0推 即與正數反過來
#include <bits/stdc++.h> #define INF 0x3f3f3f3f using namespace std; int s[105],f[105],dp[1000*100*2+5]; int main() { int n; while(~scanf("%d",&n)) {View Codeint mid=n*1000; int ed=mid*2+5; for(int i=0;i<n;i++) scanf("%d%d",&s[i],&f[i]); memset(dp, -INF, sizeof(dp)); dp[mid]=0; for(int i=0;i<n;i++) { if(s[i]>=0) { for(int j=ed;j>=s[i];j--) dp[j]=max(dp[j],dp[j-s[i]]+f[i]); } else { for(int j=s[i];j-s[i]<ed;j++) dp[j]=max(dp[j],dp[j-s[i]]+f[i]); } } int ans=-ed; for(int i=mid;i<ed;i++) if(dp[i]>=0) ans=max(ans,i-mid+dp[i]); printf("%d\n",ans); } return 0; }
USACO 2003 Fall Orange Cow Exhibition /// 負數01背包 oj22829