转自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的更多相关文章

  1. hdu 4778 Gems Fight! 博弈+状态dp+搜索

    作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4102743.html 题目链接:hdu 4778 Gems Fight! 博弈+状态dp+搜 ...

  2. Hdu 4778 Gems Fight! (状态压缩 + DP)

    题目链接: Hdu 4778 Gems Fight! 题目描述: 就是有G种颜色,B个背包,每个背包有n个宝石,颜色分别为c1,c2............两个人轮流取背包放到公共容器里面,容器里面有 ...

  3. hdu 4778 Gems Fight! 状态压缩DP

    Gems Fight! Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 327680/327680 K (Java/Others)T ...

  4. hdu 3247 AC自动+状压dp+bfs处理

    Resource Archiver Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 100000/100000 K (Java/Ot ...

  5. hdu 2825 aC自动机+状压dp

    Wireless Password Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

  6. HDU 5765 Bonds(状压DP)

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5765 [题目大意] 给出一张图,求每条边在所有边割集中出现的次数. [题解] 利用状压DP,计算不 ...

  7. hdu 3681(bfs+二分+状压dp判断)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3681 思路:机器人从出发点出发要求走过所有的Y,因为点很少,所以就能想到经典的TSP问题.首先bfs预 ...

  8. hdu 4856 Tunnels (bfs + 状压dp)

    题目链接 The input contains mutiple testcases. Please process till EOF.For each testcase, the first line ...

  9. HDU 4272 LianLianKan (状压DP+DFS)题解

    思路: 用状压DP+DFS遍历查找是否可行.假设一个数为x,那么他最远可以消去的点为x+9,因为x+1~x+4都能被他前面的点消去,所以我们将2进制的范围设为2^10,用0表示已经消去,1表示没有消去 ...

随机推荐

  1. Tarjan求强联通分量+缩点

    提到Tarjan算法就不得不提一提Tarjan这位老人家 Robert Tarjan,计算机科学家,以LCA.强连通分量等算法闻名.他拥有丰富的商业工作经验,1985年开始任教于普林斯顿大学.Tarj ...

  2. Bootstrap 响应式表格

    响应式表格 通过把任意的 .table 包在 .table-responsive class 内,您可以让表格水平滚动以适应小型设备(小于 768px).当在大于 768px 宽的大型设备上查看时,您 ...

  3. C# 读App.config配置文件[2]: .Net Core框架

    C# 读App.config配置文件[1]:.Net Framework框架 C# 读App.config配置文件[2]: .Net Core框架 网上都是.net framework读取配置文件的方 ...

  4. 总结:JavaScript异步、事件循环与消息队列、微任务与宏任务

    本人正在努力学习前端,内容仅供参考.由于各种原因(不喜欢博客园的UI),大家可以移步我的github阅读体验更佳:传送门,喜欢就点个star咯,或者我的博客:https://blog.tangzhen ...

  5. 使Linux支持exFAT和NTFS格式的磁盘

    Linux支持exFAT和NTFS Linux系统默认可以自动识别到fat32格式的盘,但fat32支持的文件不能大于4G,所以只能将移动硬盘和U盘格式化为NTFS和exFAT这两种格式的,对于U盘最 ...

  6. DocDokuPLM 2.5安装

    安装记录:(大部分是环境安装和配置) 未完待续.

  7. day03变量补充和数据类型

    1.变量的内存管理机制 引用计数:存放值的内存地址绑定的变量个数 垃圾:引用计数为0的内存地址 引用计数增加: age = 18 x = age 引用计数减少: ①age = 19 ②del x 值的 ...

  8. linux查找和替换命令

    http://blog.csdn.net/imyang2007/article/details/8105499 命令的东西应该多练,熟能生巧.

  9. Disqus 升级到3.0以上版本的评论同步问题

    Disqus从2.*升级3.*时,Knowlege Base的文章不显示Disqus评论, 解决方法:在Disqus的Advanced Settings中勾选Render Comments JavaS ...

  10. CentOS 下通过命令登录Mysql

    CentOS 下通过命令登录Mysql: mysql -uroot -p 按回车键后输入密码