2333333333333333333333333333333333333333333333

啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊

辣鸡出题人辣鸡出题人辣鸡出题人辣鸡出题人辣鸡出题人辣鸡出题人

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#include<algorithm>
#define inf 1000000007
using namespace std;
int n,m,t,wh[][],dis[][],x[],y[],tab[][][][],pre[][],fro[][][][],f[(<<)+][][];
int dx[]={,-,,,},dy[]={,,,,-};
bool map[][],vis[][];
char s[];
queue <int> q;
void reset()
{
for (int i=;i<=n;i++)
for (int j=;j<=m;j++)
dis[i][j]=inf;
while (!q.empty()) q.pop();
memset(vis,false,sizeof(vis));
}
bool judge(int x,int y)
{
if ((x>=) && (x<=n) && (y>=) && (y<=m) && (!map[x][y]))
return true;
return false;
}
void spfa(int pos,int dir)
{
memset(pre,,sizeof(pre));
if (!judge(x[pos]+dx[dir],y[pos]+dy[dir])) return;
dis[x[pos]+dx[dir]][y[pos]+dy[dir]]=;vis[x[pos]+dx[dir]][y[pos]+dy[dir]]=true;
q.push(x[pos]+dx[dir]);q.push(y[pos]+dy[dir]);
while (!q.empty())
{
int hx,hy;
hx=q.front();q.pop();hy=q.front();q.pop();
int p=;
while (judge(hx-p,hy))
{
if ((dis[hx-p][hy]>dis[hx][hy]+) || ((dis[hx-p][hy]==dis[hx][hy]+) && (wh[hx-p][hy]==)))
{
dis[hx-p][hy]=dis[hx][hy]+;
pre[hx-p][hy]=;
if (!vis[hx-p][hy])
{
vis[hx-p][hy]=true;
q.push(hx-p);q.push(hy);
}
}
p++;
}
p=;
while (judge(hx+p,hy))
{
if ((dis[hx+p][hy]>dis[hx][hy]+) || ((dis[hx+p][hy]==dis[hx][hy]+) && (wh[hx+p][hy]==)))
{
dis[hx+p][hy]=dis[hx][hy]+;
pre[hx+p][hy]=;
if (!vis[hx+p][hy])
{
vis[hx+p][hy]=true;
q.push(hx+p);q.push(hy);
}
}
p++;
}
p=;
while (judge(hx,hy-p))
{
if ((dis[hx][hy-p]>dis[hx][hy]+) || ((dis[hx][hy-p]==dis[hx][hy]+) && (wh[hx][hy-p]==)))
{
dis[hx][hy-p]=dis[hx][hy]+;
pre[hx][hy-p]=;
if (!vis[hx][hy-p])
{
vis[hx][hy-p]=true;
q.push(hx);q.push(hy-p);
}
}
p++;
}
p=;
while (judge(hx,hy+p))
{
if ((dis[hx][hy+p]>dis[hx][hy]+) || ((dis[hx][hy+p]==dis[hx][hy]+) && (wh[hx][hy+p]==)))
{
dis[hx][hy+p]=dis[hx][hy]+;
pre[hx][hy+p]=;
if (!vis[hx][hy+p])
{
vis[hx][hy+p]=true;
q.push(hx);q.push(hy+p);
}
}
p++;
}
vis[hx][hy]=false;
}
}
void get_tab(int pos,int dir)
{
for (int i=;i<=t+;i++)
for (int j=;j<=;j++)
{
if (judge(x[i]+dx[j],y[i]+dy[j]))
{
tab[pos][dir][i][j]=dis[x[i]+dx[j]][y[i]+dy[j]];
fro[pos][dir][i][j]=pre[x[i]+dx[j]][y[i]+dy[j]];
}
}
}
int main()
{
//freopen("secret.in","r",stdin);
//freopen("secret.out","w",stdout);
memset(map,false,sizeof(map));
scanf("%d%d%d",&n,&m,&t);
for (int i=;i<=n;i++)
{
scanf("\n%s",s);
for (int j=;j<m;j++)
if (s[j]=='#') map[i][j+]=true;
}
for (int i=;i<=t;i++)
{
scanf("%d%d",&x[i],&y[i]);
map[x[i]][y[i]]=true;
}
for (int i=;i<=t;i++)
{
for (int j=;j<=;j++)
{
if (judge(x[i]+dx[j],y[i]+dy[j]))
wh[x[i]+dx[j]][y[i]+dy[j]]=j;
}
}
scanf("%d%d",&x[t+],&y[t+]);
for (int i=;i<=t+;i++)
for (int j=;j<=;j++)
for (int k=;k<=t;k++)
for (int l=;l<=;l++)
tab[i][j][k][l]=inf;
for (int i=;i<=t;i++)
{
for (int j=;j<=;j++)
{
reset();
spfa(i,j);
get_tab(i,j);
}
}
reset();
spfa(t+,);
for (int i=;i<=t+;i++)
for (int j=;j<=;j++)
{
if (judge(x[i]+dx[j],y[i]+dy[j]))
{
tab[t+][][i][j]=dis[x[i]+dx[j]][y[i]+dy[j]];
fro[t+][][i][j]=pre[x[i]+dx[j]][y[i]+dy[j]];
}
}
int top=(<<t)-;
for (int s=;s<=top;s++)
for (int i=;i<=t;i++)
for (int j=;j<=;j++)
f[s][i][j]=inf;
for (int i=;i<=t;i++)
for (int j=;j<=;j++)
{
if (fro[t+][][i][j]!=j)
f[<<(i-)][i][j]=tab[t+][][i][j]+;
else f[<<(i-)][i][j]=tab[t+][][i][j];
}
for (int ss=;ss<=top;ss++)
{
for (int i=;i<=t;i++)
{
if (ss&(<<(i-)))
{
for (int j=;j<=t;j++)
{
if (ss&(<<(j-))) continue;
for (int k=;k<=;k++)
for (int l=;l<=;l++)
{
if (tab[i][k][j][l]==inf) continue;
if (fro[i][k][j][l]!=l)
f[ss|<<(j-)][j][l]=min(f[ss|<<(j-)][j][l],f[ss][i][k]+tab[i][k][j][l]+);
else f[ss|<<(j-)][j][l]=min(f[ss|<<(j-)][j][l],f[ss][i][k]+tab[i][k][j][l]);
}
}
}
}
}
int ans=inf;
for (int i=;i<=t;i++)
for (int j=;j<=;j++)
ans=min(ans,f[top][i][j]);
printf("%d\n",ans);
return ;
}

BZOJ 1556 墓地秘密的更多相关文章

  1. bzoj 1556 墓地秘密 —— 状压DP

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1556 预处理出两个障碍四个方向之间的距离(转弯次数),就可以状压DP了: 但预处理很麻烦.. ...

  2. bzoj 1556: 墓地秘密【状压dp+spfa】

    显然是状压,显然不可能把所有格子压起来 仔细观察发现只有机关周围的四个格子有用以及起点,所以我们用spfa处理出这些格子两两之间的距离(注意细节--这里写挂了好几次),然后设f[s][i]为碰完的机关 ...

  3. BZOJ1556 墓地秘密

    题意 费尽周折,终于将众将士的残骸运送到了KD军事基地地底层的大型墓地入口.KD的伙伴和战友们都参加了这次重大的送葬仪式.右边是一扇敞开的大门,进去便是墓地了,左边是一堵凹进去的墙,没有什么特别的地方 ...

  4. 洛谷 2922 BZOJ 1590 [USACO08DEC]秘密消息Secret Message

    [题意概述] 给出n个01串组成的字典和m个询问,每次询问某个01串和多少个字典中的串有相同的前缀.(前缀长度是两串中较小的部分) [题解] 直接上Trie树即可.树上每个节点记录两个信息:这个节点有 ...

  5. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  6. BZOJ 刷题总结(持续更新)

    本篇博客按照题号排序(带*为推荐题目) 1008 [HNOI2008]越狱 很经典的题了..龟速乘,龟速幂裸题,, 1010 [HNOI2008]玩具装箱toy* 斜率优化 基本算是裸题. 1012 ...

  7. bzoj1556 (DP)

    bzoj 1556 点这里打开题目 题目是求 a^2 求和: 原问题可以转化为:两个人在玩这个东西,问这两个人弄出来的序列相同的有多少种情况,操作方式不同即为一种不同的情况. 就这个问题,参考大佬的D ...

  8. bzoj 1590: [Usaco2008 Dec]Secret Message 秘密信息

    1590: [Usaco2008 Dec]Secret Message 秘密信息 Description     贝茜正在领导奶牛们逃跑.为了联络,奶牛们互相发送秘密信息.     信息是二进制的,共 ...

  9. 【BZOJ】1643: [Usaco2007 Oct]Bessie's Secret Pasture 贝茜的秘密草坪(dp)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1643 这题和完全背包十分相似, 但是不能用1维做........原因貌似是不能确定块数(还是有0的面 ...

随机推荐

  1. 吊炸天的 PHP 7 ,你值得拥有

    2015年的夏天,虽然来得不算火热,但是在互联网技术的夏天,比任何一年都更为火热. 刚刚才结束了 月底的网易.支付宝.携程以及多家云存储厂商的接连故障的坏消息,6月上旬则迎来了编程语言界两大好消息,第 ...

  2. HTML5 webSQL

    https://www.ibm.com/developerworks/cn/web/1108_zhaifeng_websqldb/   <!DOCTYPE HTML> <html&g ...

  3. POJ 1401

    #include<iostream>using namespace std;int main(){    int num;    int i;    int sum;    cin> ...

  4. NetCore第一步:千里之行 始于环境构筑

    今年的6月28号,微软发布了一个正式版本 NetCore.发布的同时,也同时发布了CoreStudio. 这个激动人心的时刻,让跨平台已经不再是什么神话. 让我们一起来开始Core的开发之旅吧. 万事 ...

  5. 2016PHP开发者大会

    大会干货: Rasmus Lerdorf——<Speeding up the Web with PHP 7> PHP 7 is here. It brings drastic perfor ...

  6. 【poj3243-Clever Y】高次同余方程-拓展BabyStepGiantStep

    http://poj.org/problem?id=3243 题意:给定X,Z,K,求一个最小的Y满足XY mod Z = K. 关于拓展BSGS的详细解释我写了一篇博文:http://www.cnb ...

  7. 性能标准:Apdex介绍

    目前的应用程序性能测试工具有多方面的局限.每种工具都有其自己对性能的定义,产生太多混乱或矛盾的数值,并缺少简洁的结论.IT经理们无法深入了解性能,而这是软件与用户对关键应用的体验有关的事. 听云作为新 ...

  8. JavaScript ECAMScript5 新特性——get/set访问器

    之前对get/set的理解一直有误,觉得get set 是对象属性方法.看了别人的博客也有很多疑问,今天系统的做了很多测试终于弄明白了.(自己通过看书和写demo测试的,如有不对欢迎大家批评指正) g ...

  9. .NET责任链模式(混合单例模式,模板方法模式)-----制作与扩展能力验证

    .NET责任链模式.单例模式.模板方法模式混用 前言 哇,看到题目挺长的,这个组合型的东西,到底能干啥呢?本篇文章来一起琢磨琢磨,这两天为了团队的软件赶工,我负责的那一块叫:插件管理器.我们团队的成员 ...

  10. C#AutoResetEvent和ManualResetEvent的区别

    一:终止状态和非终止状态 首先说说线程的终止状态和非终止状态.AutoResetEvent和ManualResetEvent的构造函数中,都有bool变量来指明线程的终止状态和非终止状态.true表示 ...