POJ 3311 Hie with the Pie (状压DP)
dp[i][j][k] i代表此层用的状态序号 j上一层用的状态序号 k是层数&1(滚动数组)
标准流程 先预处理出所有合法数据存在status里 然后独立处理第一层 然后根据前一层的max推下一层
由于最多只有60多种状态 所以这其实就是个大暴力 其实还不慢
关于为什么要反义输入地图 因为我懒得写一个地图匹配状态函数了 所以直接让地图反义匹配状态
应该算是比较简单的状压DP
然而我还是写残了WA了两次orz
#include <iostream>
#include <string>
#include <cstring>
#include <vector>
#include <algorithm>
using namespace std; int size, status[], num[];
int n, m, maze[], dp[][][]; inline bool ok(int a){
return !((a & (a >> )) || (a & a >> ));
} inline bool fit(int a, int b){
return !(a & b);
} void init(){
size = ;
memset(num, , sizeof num);
int top = << m;
for(int i = ; i < top; ++i){
if(ok(i)){
status[size] = i;
int tmp = i;
while(tmp){
if(tmp & ) num[size]++;
tmp >>= ;
}
++size;
//cout << i << ends << num[size] << endl;
}
}
} int main()
{
while(cin >> n >> m){
init(); for(int i = ; i < n; ++i){
string tmp;
cin >> tmp;
for(int j = ; j < m; ++j){
maze[i] <<= ;
//地图要反义输入
maze[i] += (tmp[j] == 'H');
}
//cout << maze[i] << endl;
} memset(dp, , sizeof dp);
for(int i = ; i < size; ++i){
if(fit(status[i], maze[])){
dp[i][][] = num[i];
//cout << status[i] << ends << num[i] << endl;
}
}
for(int i = ; i < n; ++i){
for(int j = ; j < size; ++j){
if(fit(maze[i], status[j])){
for(int k = ; k < size; ++k){
if(fit(status[j], status[k])){
int maxx = ;
for(int l = ; l < size; ++l){
if(fit(status[j], status[l])){
maxx = max(maxx, dp[k][l][!(i&)]);
}
}
dp[j][k][i&] = max(dp[j][k][i&], maxx + num[j]);
}
}
}
}
} int ans = ;
for(int i = ; i < size; ++i){
for(int j = ; j < size; ++j){
ans = max(ans, dp[i][j][!(n&)]);
}
}
cout << ans << endl;
}
return ;
}
POJ 3311 Hie with the Pie (状压DP)的更多相关文章
- 【鸽】poj3311 Hie with the Pie[状压DP+Floyd]
题解网上一搜一大坨的,不用复述了吧. 只是觉得网上dp方程没多大问题,但是状态的表示含义模糊.不同于正常哈密顿路径求解,状态表示应当改一下. 首先定义一次移动为从一个点经过若干个点到达另一个点,则$f ...
- East Central North America 2006 Hie with the Pie /// 状压dp oj22470
题目大意: 输入n,有n个地方(1~n)需要送pizza pizza点为0点 接下来n+1行每行n+1个值 表示 i 到 j 的路径长度 输出从0点到各点送pizza最后回到0点的最短路(点可重复走) ...
- poj 3311 Hie with the Pie 经过所有点(可重)的最短路径 floyd + 状压dp
题目链接 题意 给定一个\(N\)个点的完全图(有向图),求从原点出发,经过所有点再回到原点的最短路径长度(可重复经过中途点). 思路 因为可多次经过同一个点,所以可用floyd先预处理出每两个点之间 ...
- POJ 3311 Hie with the Pie (状压DP)
题意: 每个点都可以走多次的TSP问题:有n个点(n<=11),从点1出发,经过其他所有点至少1次,并回到原点1,使得路程最短是多少? 思路: 同HDU 5418 VICTOR AND WORL ...
- poj 3311 Hie with the Pie
floyd,旅游问题每个点都要到,可重复,最后回来,dp http://poj.org/problem?id=3311 Hie with the Pie Time Limit: 2000MS Me ...
- POJ 3311 Hie with the Pie(Floyd+状态压缩DP)
题是看了这位的博客之后理解的,只不过我是又加了点简单的注释. 链接:http://blog.csdn.net/chinaczy/article/details/5890768 我还加了一些注释代码,对 ...
- POJ 1321 棋盘问题(DFS & 状压DP)
用DFS写当然很简单了,8!的复杂度,16MS搞定. 在Discuss里看到有同学用状态压缩DP来写,就学习了一下,果然很精妙呀. 状态转移分两种,当前行不加棋子,和加棋子.dp[i][j]中,i代表 ...
- POJ:1185-炮兵阵地(状压dp入门)
炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K Description 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组 ...
- poj 2404 中国邮递员问题 欧拉回路判定+状压dp
/* 状压dp 邮递员问题:求经过任意点出发经过每一条边一次并回到原点. 解法:1.如果是欧拉回路那么就是所有的边的总和. 2.一般的解法,找出所有的奇度顶点,任意两个顶点匹配,即最小完美匹配,可用状 ...
随机推荐
- [Linux-脚本]排序、统计、合并命令
1.排序命令 - sort: sort可以帮我们进行排序,排序顺序按照LANG(语系环境变量)确定.据观察,sort排序以行为单位进行.排序以第一个不相同的字符决定先后顺序(只与第一个不相同的字符相关 ...
- windows 开机启动 CassiniDev(IIS替代软件)
CassiniDev(IIS替代软件) 使用asp.net的时候,要部署一个iis,或者部署iis express,有时候你嫌麻烦, 这是一个替代品. 功能完全的. 下载地址:http://cassi ...
- 将本地代码上传至github备份的操作方法
这篇文章写得是windows下的使用方法. 第一步:创建Github新账户 第二步:新建仓库 第三步:填写名称,简介(可选),勾选Initialize this repository with a R ...
- Linux Shell shortcut
Ctrl+a跳到第一个字符前Ctrl+x同上但再按一次会从新回到原位置 Details see below: Linux shell shortcut
- 炫酷的Linux终端命令大全-1
1. 命令行日常快捷键. CTRL + U ------------------------------- 剪切光标前的内容 CTRL + K ----- ...
- 项目中 poi 导出 出现html特殊符号的实体 (已解决)
导出excel 时出现 类似这样的> 符号 , 大概是存到数据库也是这样,然后jsp解析可以解析出来,但是java不认得,需要个人写出解析方法. 废话不说,贴码: /** *转换html特殊符 ...
- codeforces 724D(贪心)
题目链接:http://codeforces.com/contest/724/problem/D 题意:给定一个字符串和一个数字m,选取一个一个子序列s,使得对于字符串中任意长度为m的子序列都至少含有 ...
- 记录DIV中滚动位置刷新页面位置保持不变
一.js部分: <script type="text/javascript"> $(document).ready(function () { ...
- PS与TOP详解
一:ps ps -l 查看属于自己这次登录的PID与相关信息列出来(只与自己的bash有关) F:代表这个进程标志(process flags),说明这个进程的权限,常见号码有: 若为4表示此进程的 ...
- mac编辑器快捷键(自己摸索出来的)
control + a 行首 control + e 行尾 control + f 向右移动 control + b 向左移动 control + k 删除光标后面 cmd + delet ...