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表示没有消去 ...
随机推荐
- js 上传图片
<div class="block-input" style="height: 90px"> <span><i class=&qu ...
- LeetCode || 大杂烩w
454. 4Sum II 题意:给四个数组,每个数组内取一个数使得四个数和为0,问有多少种取法 思路:枚举为On4,考虑两个数组,On2枚举所有可能的和,将和的出现次数存入map中,On2枚举另两个数 ...
- 第2节 azkaban调度:17、azkaban的两个服务模式的安装
2.3.3.azkaban两个服务模式安装 1.确认所需软件: Azkaban Web服务安装包 azkaban-web-server-0.1.0-SNAPSHOT.tar.gz Azkaban执行服 ...
- BOM函数之history对象
前面的话 history对象保存着用户上网的历史记录,从窗口被打开的那一刻算起.由于安全方面的考虑,开发人员无法得到用户浏览器的URL,但借由用户访问过的页面列表,可以在不知道实际URL的情况下实现后 ...
- tp5对接支付宝支付简单集成
对于每个刚开始工作的新手来说,无论支付宝支付还是微信支付都是跑不掉的一个小门槛. 在加上本人比较技术比较渣(比较懒导致的),不太喜欢引用那么大的SDK,于是就简单集成了一下支付宝的支付. 但也只是只有 ...
- ios之UIImageView
UIImageView,顾名思义,是用来放置图片的.使用Interface Builder设计界面时,当然可以直接将控件拖进去并设置相关属性,这就不说了,这里讲的是用代码. 1.创建一个UIImage ...
- 如何让升级时AppleHDA不再折腾
---前提--- 1. 你得用 Clover 引导 (......) 2. 开启 kernelcache (开了也能 inject kext,还能patch kext,速度又快,为啥不开) 3. 你的 ...
- hihoCode-1043-完全背包
我们定义:best(i,x)代表i件以前的物品已经决定好选择多少件,并且在剩余奖券x的情况下的最优解. 我们可以考虑最后一步,是否再次选择i物品,在不超过持有奖券总额的情况下.上面的第二个式子的k是大 ...
- 【二分】bestcoder p1m2
模型的转化和二分check的细节挺不错的 Problem Description 度度熊很喜欢数组!! 我们称一个整数数组为稳定的,若且唯若其同时符合以下两个条件: 数组里面的元素都是非负整数. 数组 ...
- 【Java_多线程并发编程】JUC原子类——原子类中的volatile变量和CAS函数
JUC中的原子类是依靠volatile变量和Unsafe类中的CAS函数实现的. 1. volatile变量的特性 内存可见性(当一个线程修改volatile变量的值后,另一个线程就可以实时看到此变量 ...