hdu 4778 Gems Fight! 状压dp
转自wdd :http://blog.csdn.net/u010535824/article/details/38540835
题目链接:hdu 4778
状压DP
用DP[i]表示从i状态选到结束得到的最大值
代码也来自wdd
/******************************************************
* File Name: b.cpp
* Author: kojimai
* Creater Time:2014年08月13日 星期三 11时42分53秒
******************************************************/
/*
*有g种颜色的宝石,在一个容器中每s个同色宝石可以合成一个魔法石,给你b个包,里面有一定数目的宝石。
*两人博弈,每个人每个回合把一个包中的所有的宝石放进容器中,如果该操作能得到一个魔法石,则能再进行一次操作
*两个人都采取最有策略,问最终先手得到的魔法石与后手得到的魔法石的差值为多少 *状压DP,dp[i]表示i状态为起始,选到结束能得到的最大值
*i&(1<<j)==0 表示当前状态下j已经选过了
*i&(1<<j)==1 表示当前状态下j可选,转移方程:
**dp[i]=max(dp[i],dp[i^(1<<j)]+cnt) 在i^(1<<j)状态下选j能得到cnt个魔法石
**dp[i]=max(dp[i],-dp[i^(1<<j)]) 选了j之后得不到魔法石
*/
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<iostream>
using namespace std;
#define FFF -23333333
int gem[][];//每个包中的宝石
int now[];//当前状态每种宝石的数目
int dp[<<];//1表示还剩哪些位可以选,0表示该位已经选了,在该状态下一直选到结束的最大情况
int main()
{
int g,b,s;
while(cin>>g>>b>>s)//g-colornum b-bag s-least
{
if(g+b+s==)
break;
memset(gem,,sizeof(gem));
for(int i=;i<b;i++)
{
int x,y;
scanf("%d",&x);
for(int j=;j<x;j++)//读取每个包中的宝石数
{
scanf("%d",&y);
gem[i][y]++;
}
}
int all=(<<b);
dp[]=;
for(int i=;i<all;i++)
{
dp[i]=FFF;
memset(now,,sizeof(now));
for(int j=;j<b;j++)
{
if((i&(<<j))==)//当前i状态中j不可选,即之前j已经选过了,统计出所有已经选过的点得到的当前剩余的宝石
{
for(int k=;k<=g;k++)
{
now[k]=(now[k]+gem[j][k])%s;
}
}
}
/* cout<<"i="<<i<<":"<<endl;
for(int j=1;j<=g;j++)
cout<<now[j]<<' ';
*/ int cnt=;
for(int j=;j<b;j++)
{
if((i&(<<j))!=)
{
cnt=;
for(int k=;k<=g;k++)
{
int t=now[k]+gem[j][k];
cnt+=t/s;
}
//cout<<"j="<<j<<" cnt="<<cnt<<endl;
if(cnt)
dp[i]=max(dp[i],cnt+dp[i^(<<j)]);
else
dp[i]=max(dp[i],-dp[i^(<<j)]);
}
}
//cout<<"i="<<i<<" dp="<<dp[i]<<endl;
}
cout<<dp[all-]<<endl;
}
return ;
}
hdu 4778 Gems Fight! 状压dp的更多相关文章
- hdu 4778 Gems Fight! 博弈+状态dp+搜索
作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4102743.html 题目链接:hdu 4778 Gems Fight! 博弈+状态dp+搜 ...
- Hdu 4778 Gems Fight! (状态压缩 + DP)
题目链接: Hdu 4778 Gems Fight! 题目描述: 就是有G种颜色,B个背包,每个背包有n个宝石,颜色分别为c1,c2............两个人轮流取背包放到公共容器里面,容器里面有 ...
- hdu 4778 Gems Fight! 状态压缩DP
Gems Fight! Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 327680/327680 K (Java/Others)T ...
- hdu 3247 AC自动+状压dp+bfs处理
Resource Archiver Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 100000/100000 K (Java/Ot ...
- hdu 2825 aC自动机+状压dp
Wireless Password Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- HDU 5765 Bonds(状压DP)
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5765 [题目大意] 给出一张图,求每条边在所有边割集中出现的次数. [题解] 利用状压DP,计算不 ...
- hdu 3681(bfs+二分+状压dp判断)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3681 思路:机器人从出发点出发要求走过所有的Y,因为点很少,所以就能想到经典的TSP问题.首先bfs预 ...
- hdu 4856 Tunnels (bfs + 状压dp)
题目链接 The input contains mutiple testcases. Please process till EOF.For each testcase, the first line ...
- HDU 4272 LianLianKan (状压DP+DFS)题解
思路: 用状压DP+DFS遍历查找是否可行.假设一个数为x,那么他最远可以消去的点为x+9,因为x+1~x+4都能被他前面的点消去,所以我们将2进制的范围设为2^10,用0表示已经消去,1表示没有消去 ...
随机推荐
- Java IO流之字符缓冲流
字符流: 1.加入字符缓存流,增强读取功能(readLine) 2.更高效的读取数据 BufferedReader 从字符输入流读取文本,缓冲各个字符,从而实现字符.数组和行的高效读取. FileRe ...
- FIBON高精度
#include<stdio.h> #include<string.h> int u,n; ],b[],h[]; ],y[],z[]; int main() { char s( ...
- React框架搭建单页面应用package.json基本包和依赖包
{ //依赖包 "devDependencies": { //babel "babel-core": "6.24.1", "bab ...
- 【线段树 细节题】bzoj1067: [SCOI2007]降雨量
主要还是细节分析:线段树作为工具 Description 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小 ...
- 一篇关于BEM命名规范
一直以来自己对命名都是比较混乱的,并没有一个比较好的格式来命名,最近自己碰巧学习到了BEM命名规范,我想谈谈自己的理解以供自己来学习,同时也可以和各位大佬一起学习. BEM是一个很有用的方法可以创建复 ...
- python 游戏(滑动拼图Slide_Puzzle)
1. 游戏功能和流程图 实现16宫格滑动拼图,实现3个按钮(重置用户操作,重新开始游戏,解密游戏),后续难度,额外添加重置一次的按钮,解密算法的植入,数字改变为图片植入 游戏流程图 2. 游戏配置 配 ...
- Python9-装饰器-day11
import time def timmer(f): #装饰器函数 def inner(): start = time.time() ret = f() #被装饰的函数 end = time.time ...
- luogu2604 [ZJOI2010]网络扩容
先做一遍普通的dinic 然后再更改源点为超级源,超级源向原源加一条capacity=k && cost=0的边,再加上有费用的边跑最小费用最大流 #include <iostr ...
- UIDatePicker 显示时间和打印时间不一样
默认是时区为0,如下格式化一下就好啦 UIDatePicker *datePiker = [[UIDatePicker alloc] initWithFrame:CGRectMake(0, 100, ...
- [转]python开发_shelve_完整版
''' python中的shelve模块,可以提供一些简单的数据操作 他和python中的dbm很相似. 区别如下: 都是以键值对的形式保存数据,不过在shelve模块中, key必须为字符串,而值可 ...