hdu 4568 Hunter 最短路+dp
Hunter
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 2014 Accepted Submission(s): 615
The area can be represented as a N*M rectangle. Any points of the rectangle is a number means the cost of research it,-1 means James can't cross it, James can start at any place out of the rectangle, and explore point next by next. He will move in the rectangle and bring out all treasures he can take. Of course, he will end at any border to go out of rectangle(James will research every point at anytime he cross because he can't remember whether the point are researched or not).
Now give you a map of the area, you must calculate the least cost that James bring out all treasures he can take(one point up to only one treasure).Also, if nothing James can get, please output 0.

11
/*
hdu 4568 Hunter 最短路+dp problem:
给你一个n*m的地图,每走一个格子会有一定的花费.求拿到所有宝藏的最小花费 solve:
想了很久感觉没什么思路TAT
后来看别人题解可以把这个问题转换一下.
因为总共只有13个宝藏,所以我们可以处理出每个宝藏之间的最短路(即最小花费).
在弄出每个宝藏到边界的最小距离. 那么就可以看成13个点的图.找出遍历所有点的最小花费
而13个点的状态可以用二进制保存,所以dp就好. hhh-2016-08-26 21:43:38
*/
#pragma comment(linker,"/STACK:124000000,124000000")
#include <algorithm>
#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <cstring>
#include <vector>
#include <math.h>
#include <queue>
#include <map>
#define lson i<<1
#define rson i<<1|1
#define ll long long
#define clr(a,b) memset(a,b,sizeof(a))
#define scanfi(a) scanf("%d",&a)
#define scanfl(a) scanf("%I64d",&a)
#define key_val ch[ch[root][1]][0]
#define inf 0x3f3f3f3f
using namespace std;
const ll mod = 1e9+7;
const int maxn = 220; struct NODE
{
int id,len;
NODE() {}
NODE(int i,int d):id(i),len(d) {}
bool operator <(const NODE &a) const
{
return len > a.len;
}
};
int n,m;
int dx[4]= {-1,1,0,0};
int dy[4]= {0,0,-1,1};
int from[maxn][maxn];
int vis[maxn*maxn],tmap[maxn][maxn],tp[maxn][maxn],out[maxn];
int pos[maxn*maxn],dis[maxn*maxn];
void dij(int st,int fp)
{
memset(vis,0,sizeof(vis));
memset(dis,inf,sizeof(dis));
priority_queue<NODE> q;
q.push(NODE(st,0));
dis[st] = 0;
while(!q.empty())
{
NODE t = q.top();
q.pop();
int cur = t.id;
if(vis[cur]) continue;
vis[cur] = 1;
int x = cur/m,y = cur%m;
if(tp[x][y] != -1)
from[fp][tp[x][y]] = dis[cur];
if(x == n-1 || x == 0 || y == m-1 || y == 0)
{
out[fp]= min(out[fp],dis[cur]);
}
for(int i = 0; i < 4; i++)
{
int tx = x + dx[i];
int ty = y + dy[i];
if(tmap[tx][ty] == -1) continue;
if(tx >= n || tx < 0 || ty >= m || ty < 0)
continue;
if(dis[tx*m + ty] > dis[cur] + tmap[tx][ty])
{
dis[tx*m + ty] = dis[cur] + tmap[tx][ty];
q.push(NODE(tx*m + ty, dis[tx*m + ty] ));
}
}
}
return ;
} int dp[20][1 << 14];
void init()
{
memset(from,0,sizeof(from));
memset(out,inf,sizeof(out));
memset(tp,-1,sizeof(tp));
memset(dp,inf,sizeof(dp));
} int main()
{
// freopen("in.txt","r",stdin);
int T,x,y;
scanf("%d",&T);
while(T--)
{
init();
scanfi(n),scanfi(m);
for(int i = 0; i < n; i++)
{
for(int j = 0; j < m; j++)
scanfi(tmap[i][j]);
}
int q;
scanfi(q);
for(int i = 0; i < q; i++)
{
scanfi(x),scanfi(y);
tp[x][y] = i;
pos[i] = x*m + y;
}
for(int i = 0; i < q; i++)
{
from[i][i] = 0;
dij(pos[i],i);
}
for(int i = 0; i < q; i++)
{
dp[i][1 << i] = out[i]+tmap[pos[i]/m][pos[i]%m];
}
// for(int i = 0;i < q;i++)
// {
// cout << "i"<<i<<":" <<out[i] <<endl;
// for(int j = i;j < q;j++)
// cout << i <<"----"<<j<<" :" <<from[i][j]<<endl;
// }
// cout <<endl;
for(int i = 0; i < (1 << q); i++)
{
for(int j = 0; j < q; j++)
{
if( ((1 << j) & i) && i != (1 << j))
{
for(int k = 0; k < q; k++)
{
if( (i & (1 << k)) && j != k && i != (1<< k))
dp[j][i] = min(dp[k][i-(1 << j)]+from[k][j],dp[j][i]);
}
}
}
}
int ans = inf;
for(int i = 0; i < q; i++)
{
ans = min(ans,dp[i][(1<<q)-1] + out[i]);
// cout << ans <<endl;
}
printf("%d\n",ans);
}
return 0;
}
hdu 4568 Hunter 最短路+dp的更多相关文章
- HDU 4568 Hunter 最短路+TSP
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4568 Hunter Time Limit: 2000/1000 MS (Java/Others)Me ...
- HDU 4568 Hunter 最短路+状压DP
题意:给一个n*m的格子,格子中有一些数,如果是正整数则为到此格子的花费,如果为-1表示此格子不可到,现在给k个宝藏的地点(k<=13),求一个人从边界外一点进入整个棋盘,然后拿走所有能拿走的宝 ...
- HDU 4568 Hunter(最短路径+DP)(2013 ACM-ICPC长沙赛区全国邀请赛)
Problem Description One day, a hunter named James went to a mysterious area to find the treasures. J ...
- hdu 4568 Hunter(spfa预处理 + 状压dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4568 思路:首先spfa预处理出每对宝藏之间的最短距离以及宝藏到边界的最短距离,然后dp[state] ...
- hdu 4568 Hunter bfs建图+TSP状压DP
想AC的人请跳过这一段... 题目应该都能读懂.但是个人觉得这题出的很烂,意思太模糊了. 首先,进出次数只能是一次!!这个居然在题目中没有明确说明,让我在当时看到题目的时候无从下手. 因为我想到了这几 ...
- HDU 1003 Max Sum --- 经典DP
HDU 1003 相关链接 HDU 1231题解 题目大意:给定序列个数n及n个数,求该序列的最大连续子序列的和,要求输出最大连续子序列的和以及子序列的首位位置 解题思路:经典DP,可以定义 ...
- hdu 5094 Maze 状态压缩dp+广搜
作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4092176.html 题目链接:hdu 5094 Maze 状态压缩dp+广搜 使用广度优先 ...
- hdu 2829 Lawrence(斜率优化DP)
题目链接:hdu 2829 Lawrence 题意: 在一条直线型的铁路上,每个站点有各自的权重num[i],每一段铁路(边)的权重(题目上说是战略价值什么的好像)是能经过这条边的所有站点的乘积之和. ...
- BZOJ_1003_[ZJOI2006]物流运输_最短路+dp
BZOJ_1003_[ZJOI2006]物流运输_最短路+dp 题意:http://www.lydsy.com/JudgeOnline/problem.php?id=1003 分析: 这种一段一段的显 ...
随机推荐
- Exception in thread "main" expected '<document start>', but found BlockMappingStart in 'reader', line 23, column 2: nimbus.host: "master"
平台:centos-6.3-i386 jdk-7u51 storm 0.9.1 python 2.6.6 hadoop 1.2.1 启动storm的时候,遇到这个问题,百度之后,看到大家的解决方案 ...
- bzoj千题计划288:bzoj1876: [SDOI2009]SuperGCD
http://www.lydsy.com/JudgeOnline/problem.php?id=1876 高精压位GCD 对于 GCD(a, b) a>b 若 a 为奇数,b 为偶数,GCD ...
- Python 迭代器之列表解析
 [TOC] 尽管while和for循环能够执行大多数重复性任务, 但是由于序列的迭代需求如此常见和广泛, 以至于Python提供了额外的工具以使其更简单和高效. 迭代器在Python中是以C语言的 ...
- 前端面试题之css
1.请列出几个具有继承特性的css属性 font-family font-size color line-height text-align text-indent 2.阐述display: ...
- java.lang.String 类源码解读
String类定义实现了java.io.Serializable, Comparable<String>, CharSequence 三个接口:并且为final修饰. public fin ...
- CSS揭秘(三)形状
Chapter 3 1. 椭圆 椭圆的实现主要依靠 border-radius 属性,该属性确定边框切圆角的半径大小,可以指定数值 px,也可以使用百分比显示 而且该属性非常灵活,四个角可以分别设置 ...
- 【Learning】 多项式的相关计算
约定的记号 对于一个多项式\(A(x)\),若其最高次系数不为零的项是\(x^k\),则该多项式的次数为\(k\). 记为\(deg(A)=k\). 对于\(x\in(k,+ \infty)\),称\ ...
- 机器学习中 K近邻法(knn)与k-means的区别
简介 K近邻法(knn)是一种基本的分类与回归方法.k-means是一种简单而有效的聚类方法.虽然两者用途不同.解决的问题不同,但是在算法上有很多相似性,于是将二者放在一起,这样能够更好地对比二者的异 ...
- 【iOS】 含tableView的ViewController基类的实现
上篇博客写了ViewController的基类的实现,这篇博客主要写在BaseViewController的基础上实现一个含tableView控件的基类的实现,主要给包含tableView的页面来继承 ...
- JAVAFX-5 开发应用
fx 属性与布局 属性与布局是一个具备gui开发能力的开发者,快速进入开发必备的知识储备,下面简单说一说常用的属性,与布局 颜色 颜色 在 javafx.scene.paint.Color 类中提供了 ...