传送门

分析

就是飞飞侠这道题......

我们可以将这张图建成好几层,每一层可以向下一层的上下左右无代价移动,而对于每个点如果付b[i][j]的代价就可以走到比它高a[i][j]的层上。我们用这种方式优化了建边,然后跑个最短路就行了。

代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<cctype>
#include<cmath>
#include<cstdlib>
#include<queue>
#include<ctime>
#include<vector>
#include<set>
#include<map>
#include<stack>
using namespace std;
#define ri register int
const long long inf = 1e12+;
const int dx[] = {,-,,,};
const int dy[] = {,,,-,};
inline int ra(){
int x=;char s=getchar();while(!isdigit(s))s=getchar();
while(isdigit(s)){x=(x<<)+(x<<)+(s-'');s=getchar();}return x;
}
inline long long ra2(){
long long x=;char s=getchar();while(!isdigit(s))s=getchar();
while(isdigit(s)){x=(x<<)+(x<<)+(s-'');s=getchar();}return x;
}
struct node {long long wh;int x,y,z;};
bool operator < (node p,node q){return p.wh>q.wh;}
int n,m,a[][],vis[][][],x[],y[];
priority_queue<node>q;
long long b[][],d[][][],w[];
inline void dij(int s,int t1,int t2){
node A,B;
for(ri i=;i<=n;++i)
for(ri j=;j<=m;++j)
for(ri k=;k<=n+m;++k)d[i][j][k]=inf,vis[i][j][k]=;
while(!q.empty())q.pop();
d[x[s]][y[s]][]=;
A.wh=,A.x=x[s],A.y=y[s],A.z=;
q.push(A);
while(!q.empty()){
if(vis[x[]][y[]][]&&vis[x[]][y[]][]&&vis[x[]][y[]][])
break;
A=q.top();q.pop();
if(vis[A.x][A.y][A.z])continue;
vis[A.x][A.y][A.z]=;
if(A.z>){
for(ri i=;i<;++i){
if(dx[i]+A.x<||dx[i]+A.x>n)continue;
if(dy[i]+A.y<||dy[i]+A.y>m)continue;
if(d[A.x+dx[i]][A.y+dy[i]][A.z-]>A.wh){
d[A.x+dx[i]][A.y+dy[i]][A.z-]=A.wh;
B.x=A.x+dx[i],B.y=A.y+dy[i],B.z=A.z-,B.wh=A.wh;
q.push(B);
}
}
}else {
if(d[A.x][A.y][a[A.x][A.y]]>A.wh+b[A.x][A.y]){
d[A.x][A.y][a[A.x][A.y]]=A.wh+b[A.x][A.y];
B.x=A.x,B.y=A.y,B.z=a[A.x][A.y],B.wh=A.wh+b[A.x][A.y];
q.push(B);
}
}
}
w[t1]+=d[x[t1]][y[t1]][],w[t2]+=d[x[t2]][y[t2]][];
return;
}
int main(){
int out;
n=ra(),m=ra();
for(ri i=;i<=n;++i)
for(ri j=;j<=m;++j)
a[i][j]=ra(),a[i][j]=min(a[i][j],n+m);
for(ri i=;i<=n;++i)
for(ri j=;j<=m;++j)
b[i][j]=ra2();
for(ri i=;i<;++i)x[i]=ra(),y[i]=ra();
long long minn=inf;
dij(,,),dij(,,),dij(,,);
if(w[]<minn)minn=w[],out=;
if(w[]<minn)minn=w[],out=;
if(w[]<minn)minn=w[],out=;
if(minn>=inf)puts("NO");
else cout<<char(out+'X')<<endl<<minn<<endl;
return ;
}

ZROI2018普转提day1t4的更多相关文章

  1. ZROI2018普转提day6t1

    传送门 分析 记录区间最大值,线段树上二分找比这个点大的最靠前位置即可 代码 #include<iostream> #include<cstdio> #include<c ...

  2. ZROI2018普转提day6t3

    传送门 分析 居然卡哈希数,万恶的出题人...... 感觉我这个方法似乎比较呆,我的代码成功成为了全网最慢的代码qwq 应该是可以直接哈希的 但由于我哈希学的不好又想练练线段树维护哈希,于是就写了个线 ...

  3. ZROI2018普转提day7t1

    传送门 分析 一道有意思的小题... 我们发现如果$(1,1)$为白色,则将其变为白色需要偶数次操作,而如果为黑色则需要奇数次操作 我们知道要让A赢需要奇数次操作,所以我们只需要判断$(1,1)$的颜 ...

  4. ZROI2018普转提day7t2

    传送门 分析 首先我们不难想到我们一定可以将每一个点分开算,然后看这个点被几个矩形包含 于是对于位置为$(i,j)$的点它被包含的次数为$i * (n-i+1) * j * (m-j+1)$ 这个式子 ...

  5. ZROI2018普转提day1t1

    传送门 分析 我们先二分一下最终的平均值mid,然后让序列中的每一个数都减去这个mid,之后用新序列的前缀和建一棵线段树,枚举起点i,然后求出此时在i+L-1~i+R-1范围内的前缀和的最大值,用这个 ...

  6. ZROI2018普转提day2t4

    传送门 分析 考场上暴力水过好评... 然后我的st表查询似乎是log的,然后log三方跑的比log方快,qwq. 我们发现如果一个区间的最小值就是这个区间的gcd,则这个区间合法.所以我们二分区间长 ...

  7. ZROI2018普转提day2t2

    传送门 分析 我们发现2R+C实际就相当于R行C列的子集的个数.因此我们可以将所有集合的子集个数转换为每个集合属于的集合的个数.所以我们可以求出: 这个式子的意义为对于选i行j列的情况的所有方案乘上i ...

  8. ZROI2018普转提day2t1

    传送门 分析 我们通过仔细研究不难发现对于一次交换(i,i+1)的操作之后,在i之前的点就不可能跑到i之后,i+1之后的的点也不可能跑到i+1之前,所以这个序列在一次交换之后就相当于被分成了两个部分. ...

  9. ZROI2018普转提day2t3

    传送门 分析 考试的时候sb了......我们发现可以按照先序遍历将一棵树变成一个序列,而不需要删的数的数量便是最长上升子序列的长度,但是还有一个问题就是如果在5和7之间有3个空的位置就无法填入合法的 ...

随机推荐

  1. 条款47:请使用traits class表示类型信息

    在stl的算法中,我们的希望往往是根据不同的迭代器类型进行不同的更有效率的操作: template<typename IterT, typename DistT> void advance ...

  2. MySQL 添加、查看字段注释

    语法: 创建表时的COMMENT内容,要查看这些内容,使用命令: show full fields from '表名称'; 查看tb_usr表字段注释: 创建新表的脚本中, 可在字段定义脚本中添加co ...

  3. 两个VLC实现播放串流测试

    实现原理: 一个VLC打开视频文件发布串流(格式HTTP.RTP.RTSP等),另一个VLC打开串流播放 发布串流步骤: 1.菜单“媒体”->“流”,先添加视频文件.选择“串流”,如下图: 2. ...

  4. OSI七层与TCP/IP五层网络架构

    OSI七层模型   OSI中的层 功能 TCP/IP协议族 应用层 文件传输,电子邮件,文件服务,虚拟终端 TFTP,HTTP,SNMP,FTP,SMTP,DNS,Telnet 表示层 数据格式化,代 ...

  5. 搭建了一个Apache+Php+MySQL的服务器。要如何通过Apache发布网站使得其他的电脑可以通过局域网访问?

         源址: 1.网站的代码放在文件夹“www”下: 2.配置apache允许他人访问网站:在wamp/apache/apache版本/conf的httpd.conf文件修改代码如下: Optio ...

  6. String format方法的应用

    String str=null; str=String.format("Hi,%s", "小超"); System.out.println(str); str= ...

  7. FastAdmin 的 Bootstrap-Table 如何合并字段?

    FastAdmin 的 Bootstrap-Table 如何合并字段? ★hey-成都 14:13:34 把下面那个字段合并到上面那个字段是用什么方法 ^★暗物质-江西 14:17:21 city加上 ...

  8. CentOS 7安装Azcopy

    Azcopy是Azure存储一个非常好用的工具.本文将介绍如何在CentOS7下安装的过程. 更新:目前需要.net core 2.0版本.具体下载地址大家自己搜索. 1 安装.net core 1. ...

  9. vuex的实用知识点

    本文系统介绍vuex的全部内容 为什么用vuex 组件通信知道吧,相信很多同学,刚学的时候很难懂,实时上在实际应用中,大型项目如果使用最原始的组件通信会非常的麻烦,主要体现在多层嵌套的组件之间的通信, ...

  10. 2014.2.23 datagridview显示图片的方法

    DataTable dt = new DataTable(); dt.Columns.Add("", typeof(byte[])); dt.Rows.Add(File.ReadA ...