[知识点]状态压缩DP
// 此博文为迁移而来,写于2015年7月15日,不代表本人现在的观点与看法。原始地址:http://blog.sina.com.cn/s/blog_6022c4720102w6jf.html

其中k`表示上一行的状态,num(k)表示在当前行状态为k的情况下棋子的总个数。
#include cstring
#include algorithm
using namespace std;
{
int s=0,tmp=0;
while (x)
{
if (s && (x & 1)) return -1;
if (s=(x & 1)) tmp++;
x=x>>1;
}
return tmp;
}
{
int n,m,t;
while (scanf("%d %d %d",&n,&m,&t)!=EOF)
{
if (n<m) swap(n,m);
memset(f,0,sizeof(f));
f[0][0][0]=1;
for (int i=1;i<=n;i++)
for (int r=0;r<=t;r++)
for (int j=0;j<(1<<m);j++) // 当前的状态
{
int num=getNum(j); // 棋子个数
if (num==-1 || num>r) continue;
for (int k=0;k<(1<<m);k++) // 上次的状态转移
{
if (getNum(k)==-1 || k&j) continue;
f[i][j][r]+=f[i-1][k][r-num];
}
}
long long ans=0;
for (int i=0;i<(1<<m);i++) ans+=f[n][i][t];
printf("%lld\n",ans);
}
return 0;
}
分析:同样地,这道题用f[i][j][k]表示从(1,1)到(i,j)子矩阵中当所走路径状态为k的时候所得的最小权值,那么状态则是根据所走路径转换为二进制在转换为十进制来转移,就不多说了,看代码。
#include<cstring>
#define MAXN 11
#define INF 0x3f3f3f3f
const int two[MAXN]={1,2,4,8,16,32,64,128,256,512};
{
int temp=ki;
for (int i=9;i>=0;i--) if (temp>=two[i]) { temp-=two[i]; if (i==now) return ki; }
return (ki+two[now]);
}
{
memset(f,INF,sizeof(f));
for (int i=1;i<=10;i++)
for (int j=1;j<=10;j++) scanf("%d",&map[i][j]);
int t1=two[map[1][1]],t2=0;
f[1][1][t1]=map[1][1];
for (int i=2;i<=10;i++)
{
t2=getNum(t1,map[1][i]);
f[1][i][t2]=f[1][i-1][t1]+map[1][i];
t1=t2;
}
t1=two[map[1][1]];
for (int i=2;i<=10;i++)
{
t2=getNum(t1,map[i][1]);
f[i][1][t2]=f[i-1][1][t1]+map[i][1];
t1=t2;
}
for (int i=2;i<=10;i++)
for (int j=2;j<=10;j++)
{
for (int ki=1;ki<=(1<<10)-1;ki++)
{
if (f[i-1][j][ki]==INF) continue;
int k=getNum(ki,map[i][j]);
f[i][j][k]=min(f[i][j][k],f[i-1][j][ki]+map[i][j]);
}
for (int ki=1;ki<=(1<<10)-1;ki++)
{
if (f[i][j-1][ki]==INF) continue;
int k=getNum(ki,map[i][j]);
f[i][j][k]=min(f[i][j][k],f[i][j-1][ki]+map[i][j]);
}
}
for (int i=1;i<=1023;i++) if (f[3][3][i]!=INF) printf("i=%d %d\n",i,f[3][3][i]);
printf("%d",f[10][10][1023]);
return 0;
}
[知识点]状态压缩DP的更多相关文章
- hdu4336 Card Collector 状态压缩dp
Card Collector Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- 浅谈状态压缩DP
浅谈状态压缩DP 本篇随笔简单讲解一下信息学奥林匹克竞赛中的状态压缩动态规划相关知识点.在算法竞赛中,状压\(DP\)是非常常见的动规类型.不仅如此,不仅是状压\(DP\),状压还是很多其他题目的处理 ...
- hoj2662 状态压缩dp
Pieces Assignment My Tags (Edit) Source : zhouguyue Time limit : 1 sec Memory limit : 64 M S ...
- POJ 3254 Corn Fields(状态压缩DP)
Corn Fields Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 4739 Accepted: 2506 Descr ...
- HDU-4529 郑厂长系列故事——N骑士问题 状态压缩DP
题意:给定一个合法的八皇后棋盘,现在给定1-10个骑士,问这些骑士不能够相互攻击的拜访方式有多少种. 分析:一开始想着搜索写,发现该题和八皇后不同,八皇后每一行只能够摆放一个棋子,因此搜索收敛的很快, ...
- DP大作战—状态压缩dp
题目描述 阿姆斯特朗回旋加速式阿姆斯特朗炮是一种非常厉害的武器,这种武器可以毁灭自身同行同列两个单位范围内的所有其他单位(其实就是十字型),听起来比红警里面的法国巨炮可是厉害多了.现在,零崎要在地图上 ...
- 状态压缩dp问题
问题:Ignatius has just come back school from the 30th ACM/ICPC. Now he has a lot of homework to do. Ev ...
- BZOJ-1226 学校食堂Dining 状态压缩DP
1226: [SDOI2009]学校食堂Dining Time Limit: 10 Sec Memory Limit: 259 MB Submit: 588 Solved: 360 [Submit][ ...
- Marriage Ceremonies(状态压缩dp)
Marriage Ceremonies Time Limit:2000MS Memory Limit:32768KB 64bit IO Format:%lld & %llu ...
随机推荐
- linux退出vi
linux退出vi操作,可以先按“esc”,再按“:”,“x”即可,这是要保存退出. 假如是修改过的,不保存,即是:先按 : ,然后输入 q! 回车 假如未改动,即先按 : ,然后输入 ...
- 让那些为Webkit优化的网站也能适配IE10(转载)
转载地址:http://www.w3cplus.com/css3/adapting-your-webkit-optimized-site-for-internet-explorer-10.html 特 ...
- OCJP(1Z0-851) 模拟题分析(二)over
Exam : 1Z0-851 Java Standard Edition 6 Programmer Certified Professional Exam 以下分析全都是我自己分析或者参考网上的,定有 ...
- Macbook Pro安装win7
1.进入OS X系统,在实用工具中打开Boot Camp助理 2.用磁盘工具对磁盘进行分区,将需要安装win7的分区格式化成FAT格式 3.用Boot Camp对磁盘进行分割,然后插入win7的安装光 ...
- java调用shell获取返回值
转自:http://blog.csdn.net/tengdazhang770960436/article/details/12014839 1.shell文件return.sh echo 1 echo ...
- HR外包系统 - 客户员工 发薪需求/个税需求 设置
最好,客户公司层面进行设置,如果单一情况,只需要设置公司,如果不是单一情况,设置员工, 另外员工只能从公司设置好的地方选择过来. 增强系统简便设置和设置的灵活性.
- Axure 全局辅助线(转)
普通辅助线作用于当前页 全局作用于所有页面 , 包括新建页面 创建普通辅助线直接拉出来 创建全局辅助线 , 在拉出来的时候按住 Ctrl 默认情况下 , 颜色不同 辅助线可以多选 , 用拖选 或 按 ...
- Linux学习笔记(2)Linux学习注意事项
1 学习Linux的注意事项 ① Linux严格区分大小写 ② Linux中所有内容均以文件形式保存,包括硬件,如硬件文件是/deb/sd[a-p] ③ Linux不靠扩展名区分文件类型,但有的文件是 ...
- 日常UVA题目英语积累
quote应该是引号的意思 Two matches (i, j) and (p, q) are called independent when i = p if and only if j = q. ...
- Servlet的request应用案例
request部分用法如代码: AServlet package cn.yzu; import java.io.IOException; import javax.servlet.ServletExc ...