USACO2014FebruaryGold Cow Decathlon
来源:互联网 发布:coco2d js 使用九宫图 编辑:程序博客网 时间:2024/06/16 17:31
可利用状压DP 只有2的20次方空间 枚举n匹马的使用情况
dp[k]表示当前状态下马的使用情况能达到的最大奖金值 比如10111 即使用第一 第二 第三 第五匹马完成前4个项目所能达到的奖金的最大值 故可以找到没有使用过的马 完成下一个项目 然后更新dp值
#include<stdio.h>#include<algorithm>#include<iostream>#include<string>#include<string.h>#include<vector>#define M 1200005using namespace std;int n,b;struct node{ int p,g;};int dp[M];//存当前几匹马使用状态下最高获得的奖金int s[1005][1005];vector<node>edge[25];int main(){ scanf("%d %d",&n,&b); while(b--){ int p,g,a; scanf("%d %d %d",&p,&g,&a); edge[p].push_back((node){g,a}); } for(int i=0;i<n;i++)for(int j=1;j<=n;j++)scanf("%d",&s[i][j]); for(int i=0;i<(1<<n)-1;i++){ int cnt=__builtin_popcount(i);//求出二进制位上有多少个1 int x=i; for(int j=0;j<n;j++){ if(x&(1<<j))continue;//找到没有使用的马 int sum=dp[x]+s[j][cnt+1],ans=0; for(int k=0;k<edge[cnt+1].size();k++) if(sum>=edge[cnt+1][k].p)ans+=edge[cnt+1][k].g; dp[x|(1<<j)]=max(dp[x|(1<<j)],sum+ans);//更新获得的奖金 } } printf("%d",dp[(1<<n)-1]); return 0;}
1 0
- USACO2014FebruaryGold Cow Decathlon
- USACO2014FebruaryGold Cow Decathlon
- 【Usaco2014 Feb】Cow Decathlon
- bzoj3446[Usaco2014 Feb]Cow Decathlon全能奶牛
- 【USACO】2014 Feb Cow Decathlon 全能奶牛
- bzoj3446 [Usaco2014 Feb]Cow Decathlon 状压DP
- USACO2014FebruaryGold Roadblock
- USACO2014FebruaryGold Roadblock Dijkstra+路径还原
- cow
- COW
- cow
- cow & bridge
- Cow Man
- Cow Picnic
- Cow Solitaire
- Cow Bowling
- Cow Pedigrees
- cow tour
- C++的get()函数与getline()函数使用与比较
- js中sort()方法的用法,参数以及排序原理
- POJ 2407 Relatives 已翻译
- 联想拖拉机逆向之旅
- 高性能索引策略二
- USACO2014FebruaryGold Cow Decathlon
- 仿射变换
- 操作系统课设——移动臂模拟调度算法
- [倾力之作]android轻量级网络请求框架MyHttputils
- linux下ODBC连接mysql
- iOS自学笔记之UIProgressView和UIActivityIndicatorView
- C# 计算一段程序运行时间
- 谓词函数、函数对象
- oj搭