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

然后将每个点拆成四个点,四个点之间如果没跨越最短路树的树边,那就连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. @bzoj - 4356@ Ceoi2014 Wall

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 给出一个N*M的网格图,有一些方格里面存在城市,其中首都位于网格 ...

  2. bzoj AC倒序

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

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

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

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

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

  5. UVALive 2453 Wall (凸包)

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

  6. write/wall 1

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

  7. Image Wall - jQuery & CSS3 图片墙效果

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

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

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

  9. POJ 1113:Wall

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

随机推荐

  1. [转]嵌入式SQC文件编译

      Src Url:http://blog.csdn.net/cws1214/article/details/12996351   A.预编译部分  1.预编译DB2篇 1.1 什么是DB2预编译 在 ...

  2. 造成ORA-12560: TNS: 协议适配器错误的问题的原因有三个:

    1.监听服务没有启动 windows平台个一如下操作:开始---程序---管理工具---服务,打开服务面板,启动oraclehome92TNSlistener服务. 2.数据库实例没有启动 windo ...

  3. sql server 的cpu使用率过高的分析

    有哪些SQL语句会导致CPU过高? 1.编译和重编译 编译是 Sql Server 为指令生成执行计划的过程.Sql Server 要分析指令要做的事情,分析它所要访问的表格结构,也就是生成执行计划的 ...

  4. JS中级 - 02:表单、表格

    getElementsByTagName() getElementsByTagName() 方法可返回带有指定标签名的对象的集合. getElementsByClassName() 返回文档中所有指定 ...

  5. Arch Linux 安装、配置、美化和优化

    国庆假期玩了下Arch Linux,发现这货跟Ubuntu之流相差甚远,甚难调教,而且安裝过程全命令行,会有各种问题,各种知识... --- 安装引导器--- -------------------- ...

  6. Shell编程基础教程2--变量和运算符

    2.变量和运算符 2.1.变量的类型 本地变量:环境变量:变量替换(显示变量):位置变量:标准变量:特殊变量: 2.2.本地变量 本地变量在用户现在的shell生命周期的脚本中使用 在命令行, LOC ...

  7. 你可能不知道的java、python、JavaScript以及jquary循环语句的区别

    一.概述 java循环语句分为四种形式,分别是 while, do/while, for, foreach: python中循环语句有两种,while,for: JavaScript中循环语句有四种, ...

  8. 在PYTHON3中,使用Asyncio来管理Event loop

    #!/usr/bin/env python # -*- coding: utf-8 -*- import asyncio import datetime import time def functio ...

  9. python中的Iterable, Iterator,生成器概念

    https://nychent.github.io/articles/2016-05/about-generator.cn 这个深刻 谈起Generator, 与之相关的的概念有 - {list, s ...

  10. .NET Nancy 详解(二) 简易路由实现

    继续上面的简易版本,有意思的点剩下便是路由实现了. 路由注册 首先,来看一下基本的路由注册过程. public FakeNancyModuleWithoutBasePath() { Delete[&q ...