求出左上角到每个需要保护的点左上角的最短路树,那么最优解一定圈住了它们。

然后将每个点拆成四个点,四个点之间如果没跨越最短路树的树边,那就连0权边。

每个需要保护的点四周4个点都不可通行,求出最短路即为答案。

时间复杂度$O(nm\log(nm))$。

#include<cstdio>
#include<algorithm>
#include<queue>
using namespace std;
typedef long long ll;
typedef pair<ll,int>P;
const int N=410,M=2600000;
const ll inf=1LL<<60;
int n,m,i,j,k,x,y,a[N][N],b[N][N],c[N][N];
int tot,f[N][N],X[N*N],Y[N*N],pre[N][N];
ll d[N][N];
bool vis[N][N],mark[N][N][4],del[N*N*4];
priority_queue<P,vector<P>,greater<P> >Q;
inline void read(int&a){char c;while(!(((c=getchar())>='0')&&(c<='9')));a=c-'0';while(((c=getchar())>='0')&&(c<='9'))(a*=10)+=c-'0';}
inline void ext(int x,int y,ll z,int p){
  if(!f[x][y]||d[x][y]<=z)return;
  d[x][y]=z,pre[x][y]=p;
  Q.push(P(z,f[x][y]));
}
void dfs(int x,int y){
  if(x==1&&y==1)return;
  if(vis[x][y])return;
  vis[x][y]=1;
  int X=x,Y=y,D=pre[x][y];
  mark[x][y][D]=1;
  if(!D)X--;
  if(D==1)X++;
  if(D==2)Y--;
  if(D==3)Y++;
  mark[X][Y][D^1]=1;
  dfs(X,Y);
}
namespace G{
int f[N][N][4],X[N*N*4],Y[N*N*4],Z[N*N*4];
int g[N*N*4],v[M],w[M],nxt[M],ed;
ll d[N*N*4];
inline void add(int x,int y,int z){
  if(del[x]||del[y])return;
  v[++ed]=y;w[ed]=z;nxt[ed]=g[x];g[x]=ed;
  v[++ed]=x;w[ed]=z;nxt[ed]=g[y];g[y]=ed;
}
void work(){
  Q.push(P(d[2]=0,2));
  while(!Q.empty()){
    P t=Q.top();Q.pop();
    if(d[x=t.second]<t.first)continue;
    for(i=g[x];i;i=nxt[i])if(d[x]+w[i]<d[v[i]])Q.push(P(d[v[i]]=d[x]+w[i],v[i]));
  }
  printf("%lld",d[3]);
}
}
int main(){
  read(n),read(m);
  for(i=1;i<=n;i++)for(j=1;j<=m;j++)read(a[i][j]);
  for(i=1;i<=n;i++)for(j=1;j<=m+1;j++)read(b[i][j]);
  for(i=1;i<=n+1;i++)for(j=1;j<=m;j++)read(c[i][j]);
  for(i=1;i<=n+1;i++)for(j=1;j<=m+1;j++)f[i][j]=++tot,d[i][j]=inf,X[tot]=i,Y[tot]=j;
  Q.push(P(d[1][1]=0,1));
  while(!Q.empty()){
    P t=Q.top();Q.pop();
    if(d[x=X[t.second]][y=Y[t.second]]<t.first)continue;
    ext(x+1,y,d[x][y]+b[x][y],0);
    ext(x-1,y,d[x][y]+b[x-1][y],1);
    ext(x,y+1,d[x][y]+c[x][y],2);
    ext(x,y-1,d[x][y]+c[x][y-1],3);
  }
  for(i=1;i<=n;i++)for(j=1;j<=m;j++)if(a[i][j])dfs(i,j);
  for(tot=0,i=1;i<=n+1;i++)for(j=1;j<=m+1;j++)for(k=0;k<4;k++){
    G::f[i][j][k]=++tot,G::X[tot]=i,G::Y[tot]=j,G::Z[tot]=k;
    G::d[tot]=inf;
  }
  for(del[1]=i=1;i<=n;i++)for(j=1;j<=m;j++)if(a[i][j]){
    del[G::f[i][j][3]]=1;
    del[G::f[i+1][j][1]]=1;
    del[G::f[i][j+1][2]]=1;
    del[G::f[i+1][j+1][0]]=1;
  }
  for(i=1;i<=n;i++)for(j=1;j<=m+1;j++){
    G::add(G::f[i][j][2],G::f[i+1][j][0],b[i][j]);
    G::add(G::f[i][j][3],G::f[i+1][j][1],b[i][j]);
  }
  for(i=1;i<=n+1;i++)for(j=1;j<=m;j++){
    G::add(G::f[i][j][1],G::f[i][j+1][0],c[i][j]);
    G::add(G::f[i][j][3],G::f[i][j+1][2],c[i][j]);
  }
  for(i=1;i<=n+1;i++)for(j=1;j<=m+1;j++){
    if(!mark[i][j][0])G::add(G::f[i][j][0],G::f[i][j][1],0);
    if(!mark[i][j][1])G::add(G::f[i][j][2],G::f[i][j][3],0);
    if(!mark[i][j][2])G::add(G::f[i][j][0],G::f[i][j][2],0);
    if(!mark[i][j][3])G::add(G::f[i][j][1],G::f[i][j][3],0);
  }
  G::work();
  return 0;
}

  

BZOJ4356 : Ceoi2014 Wall的更多相关文章

  1. [poj1113][Wall] (水平序+graham算法 求凸包)

    Description Once upon a time there was a greedy King who ordered his chief Architect to build a wall ...

  2. gcc -Wall -pedantic -ansi(转载)

    转载自R-G-Y-CQ的新浪博客 -Wall显示所有的警告信息 -Wall选项可以打开所有类型的语法警告,以便于确定程序源代码是否是正确的,并且尽可能实现可移植性. 对Linux开发人员来讲,GCC给 ...

  3. UVALive 2453 Wall (凸包)

    题意:给你一个多边形的城堡(多个点),使用最短周长的城墙将这个城堡围起来并保证城墙的每个点到城堡上的每个点的距离都不小于l 题解:因为两点间的直线一定比折线短,所以这样做 先使用所有点求得一个凸包,接 ...

  4. write/wall 1

    linux:/opt/software/lktest/c # wallhellllllllllllllllllllooooooooooooooooo^[[AasZZZZZZ^Clinux:/opt/s ...

  5. Image Wall - jQuery &amp; CSS3 图片墙效果

    今天我们要为您展示如何基于 jQuery 和 CSS3 创建一个整洁的图片墙效果.我们的想法是在页面上洒上一些大小不同的缩略图,并在当我们点击图片时候显示丝带,会显示一些描述,再次点击缩略图时,丝带将 ...

  6. Jenkins项目构建结果通知Email的替代方案Wall Display插件

    插件:https://wiki.jenkins-ci.org/display/JENKINS/Wall+Display+Plugin 效果: 操作: 直接在一个大屏幕上打开这个项目的构建页面,那么每次 ...

  7. POJ 1113:Wall

    原文链接:https://www.dreamwings.cn/poj1113/2832.html Wall Time Limit: 1000MS   Memory Limit: 10000K Tota ...

  8. [书]WALL&#183;E、龙与地下铁、中国美丽的故事、故事新编、四十自述、书虫、人工智能、大话数据结构

    下午有时间,逛了逛了书城,看到了一些书.在这里总结一些自己的感受.   一.<龙与地下铁>     这本书是我首先看到的,就在靠前的新书区.是小说,我没看里面的内容,但是被书封皮的宣传文案 ...

  9. hdu 1348 Wall (凸包)

    Wall Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

随机推荐

  1. iOS 之APP上架

    前几天在忙着上线,尽管之前已经上线过一次,但由于本身比较菜,还是状况百出. 好在今天终于成功提交,因此来写写心得. 如果是第一次上线,推荐这篇文章: http://jingyan.baidu.com/ ...

  2. Java中的夏令时问题

    因为在用C#做项目的时候被夏令时坑过一回,所以这次将在java中的时区转换信息做一下记录,很简单 SimpleDateFormat inputFormat = new SimpleDateFormat ...

  3. iOS基础框架的搭建/国际化操作

    1.基础框架的搭建 1.1 pod引入常用的第三方类库 1.2 创建基础文件夹结构/目录结构 Resource———存放声音/图片/xib/storyboard 等资源文件 Define——宏定义, ...

  4. [Android]IllegalStateException: Could not find method onBind(View)

    FATAL EXCEPTION: main Process: org.diql.aidldemo, PID: 2274 java.lang.IllegalStateException: Could n ...

  5. poj3107 树形dp

    好久没更了.前段时间去ec-final,实力水一波,混了个铜,虽然很弱,但是可以算是对之前一段时间的回报吧. 现在每天忙着复习,逃课太多,啥都不会...不想挂科啊!!Orz... 题意(简化):警察想 ...

  6. 如何删除docker images/containers

    docker images往往不知不觉就占满了硬盘空间,为了清理冗余的image,可采用以下方法: 1.进入root权限 sudo su 2.停止所有的container,这样才能够删除其中的imag ...

  7. ectouch第七讲 之ECshop模板机制整理

    网上的资源感觉还是有些用,可以看看,帮助理解,ECshop模板机制整理原文:http://blog.sina.com.cn/s/blog_6900af430100nkn8.html 一.模板引擎: E ...

  8. [无人值守安装操作系统]_FTP+TFTP+DHCP+Kickstart+PXE_中遇到的错误

    本篇记录的是实验  http://www.cnblogs.com/snsdzjlz320/p/5629127.html  过程出现的问题 问题一: PXE-E11:ARP timeout TFTP c ...

  9. URAL 1250 Sea Burial 简单Floodfill

    问这个人掉落的海域包含几个岛屿. 八方向相连为同一片海域,四方向相连为同一个岛屿.与边界相连的岛屿不算. 方法:在给定地图外面填充一圈".",从这个人掉落的地方开始进行floodf ...

  10. iOS开发-核心动画随笔

    核心动画可以让View旋转,缩放,平移(主要是操作View的layer(层)属性)但是核心动画改变的位置不是真实的位置,一切都是假象所以有时候要用到其他动画,如UIView本来封装的动画,还有定时器 ...