BZOJ4290 传送门
昨天考试考了这道题,学校评测不开O2被卡的一愣一愣的。
这种题线性复杂度就线性复杂度,为什么要卡常数。
顺便提一句,GRH大爷O(m*n*ans)的算法有90分,我的O(m*n)算法75。(万恶的STL)
这是什么烂数据(只是吐槽我们学校的数据,与BZOJ无关)
那我们来讲一讲做法:(首先,这是一道SB题)
我们考虑传送的行为:
1.如果一个传送门被穿越,那么从此以后进的那个门一定不用回去,出的那个门可以在出去以后立即打一枪替换。所以从此这两个门都不用进了
2.如果我们从一个传送门出来,那么我们一定有一个时刻枪可以打到传送门所在位置。
3.我们考虑这个位置:打完这一枪以后,在哪里开传送门并不重要,都可以到达。那么我们就贪心地走到最近的一面墙就可以了(这一步等价于建立一条从这个点到所有枪可以到达的点建立了一条长度为t+1的边(t为当前点到最近的贴墙空地的距离)
下面是代码:
/**************************************************************
Problem: 4290
User: CYZ
Language: C++
Result: Accepted
Time:2444 ms
Memory:81668 kb
****************************************************************/ #include<cstdio>
#include<queue>
#include<list>
using namespace std ; const int MAXR = + ;
int C , R ;
char M [ MAXR ] [ MAXR ] ;
int dis1 [ MAXR ] [ MAXR ] ;
int dis2 [ MAXR ] [ MAXR ] ;
bool vis [ MAXR ] [ MAXR ] ;
int s1 [ MAXR ] [ MAXR ] ;
int s2 [ MAXR ] [ MAXR ] ;
int s3 [ MAXR ] [ MAXR ] ;
int s4 [ MAXR ] [ MAXR ] ; queue < pair < int , int > > q ;
queue < pair < int , int > , list < pair < int , int > > > Q [ * + ] ;
int cx , cy ;
int ans = - ; void P ( const int x , const int y ) {
if ( x < || x > C + || y < || y > R + || dis1 [ x ] [ y ] != ) return ;
dis1 [ x ] [ y ] = ;
q . push ( make_pair ( x , y ) ) ;
} template < class T1 , class T2 >
void min_equal ( T1 & a , const T2 & b ) {
if ( a > b ) a = b ;
} template < class T1 , class T2 >
void max_equal ( T1 & a , const T2 & b ) {
if ( a < b ) a = b ;
} int main () {
/*
freopen ( "portals.in" , "r" , stdin ) ;
freopen ( "portals.out" , "w" , stdout ) ;
*/
scanf ( "%d%d" , & R , & C ) ;
for ( int x = ; x <= R ; ++ x ) scanf ( "%s" , M [ x ] + ) ;
for ( int x = ; x <= R + ; ++ x ) M [ x ] [ ] = M [ x ] [ C + ] = '#' ;
for ( int y = ; y <= C + ; ++ y ) M [ ] [ y ] = M [ R + ] [ y ] = '#' ;
for ( int x = ; x <= R ; ++ x )
for ( int y = ; y <= C ; ++ y ) {
dis2 [ x ] [ y ] = ;
if ( M [ x ] [ y ] == 'S' ) {
Q [ ] . push ( make_pair ( x , y ) ) ;
} else if ( M [ x ] [ y ] == 'C' ) {
cx = x ;
cy = y ;
}
}
for ( int x = ; x <= R + ; ++ x )
for ( int y = ; y <= C + ; ++ y )
dis1 [ x ] [ y ] = M [ x ] [ y ] == '#' ;
for ( int x = ; x <= R + ; ++ x )
for ( int y = ; y <= C + ; ++ y )
if ( M [ x ] [ y ] == '#' ) {
P ( x + , y ) ;
P ( x - , y ) ;
P ( x , y - ) ;
P ( x , y + ) ;
}
while ( ! q . empty () ) {
const int x = q . front () . first ;
const int y = q . front () . second ;
q . pop () ;
if ( dis1 [ x + ] [ y ] == ) {
dis1 [ x + ] [ y ] = dis1 [ x ] [ y ] + ;
q . push ( make_pair ( x + , y ) ) ;
}
if ( dis1 [ x - ] [ y ] == ) {
dis1 [ x - ] [ y ] = dis1 [ x ] [ y ] + ;
q . push ( make_pair ( x - , y ) ) ;
}
if ( dis1 [ x ] [ y + ] == ) {
dis1 [ x ] [ y + ] = dis1 [ x ] [ y ] + ;
q . push ( make_pair ( x , y + ) ) ;
}
if ( dis1 [ x ] [ y - ] == ) {
dis1 [ x ] [ y - ] = dis1 [ x ] [ y ] + ;
q . push ( make_pair ( x , y - ) ) ;
}
}
for ( int x = ; x <= R ; ++ x )
for ( int y = ; y <= C ; ++ y ) {
dis2 [ x ] [ y ] = - ;
if ( s1 [ x ] [ y ] == )
for ( int x2 = x ; M [ x2 ] [ y ] != '#' ; ++ x2 )
s1 [ x2 ] [ y ] = x ;
if ( s3 [ x ] [ y ] == )
for ( int y2 = y ; M [ x ] [ y2 ] != '#' ; ++ y2 )
s3 [ x ] [ y2 ] = y ;
}
for ( int x = R ; x >= ; -- x )
for ( int y = C ; y >= ; -- y ) {
if ( s2 [ x ] [ y ] == )
for ( int x2 = x ; M [ x2 ] [ y ] != '#' ; -- x2 )
s2 [ x2 ] [ y ] = x ;
if ( s4 [ x ] [ y ] == )
for ( int y2 = y ; M [ x ] [ y2 ] != '#' ; -- y2 )
s4 [ x ] [ y2 ] = y ;
}
for ( int t = ; ans == - ; ++ t ) {
queue < pair < int , int > ,
list < pair < int , int > > > & q = Q [ t ] ;
while ( ! q . empty () ) {
const int x = q . front () . first ;
const int y = q . front () . second ;
q . pop () ;
if ( vis [ x ] [ y ] ) continue ;
vis [ x ] [ y ] = true ;
dis2 [ x ] [ y ] = t ;
if ( x == cx && y == cy ) {
ans = t ;
break ;
}
if ( M [ x + ] [ y ] != '#' && ! vis [ x + ] [ y ] )
Q [ t + ] . push ( make_pair ( x + , y ) ) ;
if ( M [ x - ] [ y ] != '#' && ! vis [ x - ] [ y ] )
Q [ t + ] . push ( make_pair ( x - , y ) ) ;
if ( M [ x ] [ y + ] != '#' && ! vis [ x ] [ y + ] )
Q [ t + ] . push ( make_pair ( x , y + ) ) ;
if ( M [ x ] [ y - ] != '#' && ! vis [ x ] [ y - ] )
Q [ t + ] . push ( make_pair ( x , y - ) ) ;
if ( ! vis [ s1 [ x ] [ y ] ] [ y ] ) Q [ t + dis1 [ x ] [ y ] ] . push
( make_pair ( s1 [ x ] [ y ] , y ) ) ;
if ( ! vis [ s2 [ x ] [ y ] ] [ y ] ) Q [ t + dis1 [ x ] [ y ] ] . push
( make_pair ( s2 [ x ] [ y ] , y ) ) ;
if ( ! vis [ x ] [ s3 [ x ] [ y ] ] ) Q [ t + dis1 [ x ] [ y ] ] .
push ( make_pair ( x , s3 [ x ] [ y ] ) ) ;
Q [ t + dis1 [ x ] [ y ] ] .
push ( make_pair ( x , s4 [ x ] [ y ] ) ) ;
}
}
/*
for ( int x = 1 ; x <= R ; ++ x ) {
for ( int y = 1 ; y <= C ; ++ y ) printf ( "%2d " , dis2 [ x ] [ y ] ) ;
putchar ( '\n' ) ;
}*/
printf ( "%d\n" , ans ) ;
return ;
}
BZOJ4290 传送门的更多相关文章
- 【hrbust2294】修建传送门
题意 哈理工2016级新生程序设计全国邀请赛B题 n个点1~n,i到i+1的距离为a[i],现在可以在两个点之间建一个传送门,则两点之间距离为0,求建传送门后1号出发的最远距离最小是多少? 题解 a[ ...
- [openwrt 项目开发笔记]: 传送门
“Openwrt 项目开发笔记”系列传送门: [Openwrt 项目开发笔记]:Openwrt平台搭建(一) (2014-07-11 00:11) [Openwrt 项目开发笔记]:Openwrt平台 ...
- codevs2059逃出克隆岛(传送门bfs)
/* 和普通的迷宫问题类似只是多了一个叫传送门的东西 对于传送门的处理: 每当跑到传送门就把其余所有传送门周围的点都入队 传送门之间不花费时间并且从不是传送门的点走到传送门 也不花费时间花费时间的(好 ...
- unity传送门类似效果实现
简述 在传送门中,核心的玩法是在地上或者墙上打开2个可以联通的洞来实现传送的效果.以此扩展加入解谜要素构成游戏的核心. 这里尝试使用unity来实现传送门的核心功能,具体功能分析如下: 1.传送门的模 ...
- Java编译过程(传送门)
我不是要做一门编程语言,了解这个对我现在的工作也没什么帮助,纯粹好奇而已. 传送门
- Test传送门(更新中)
一.Codeforces传送门: Avito Code Challenge 2018 题解传送门 Codeforces Round #485 (Div. 2) 题解传送门 二.hihocode ...
- 【bzoj题解】题解传送门
如题,题解传送门: 1001 1008 1012
- HDU 2102 A计划(两层地图加时间限制加传送门的bfs)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=2102 A计划 Time Limit: 3000/1000 MS (Java/Others) Me ...
- JZOJ 5906. 传送门
Description 8102年,Normalgod在GLaDOS的帮助下,研制出了传送枪.但GLaDOS想把传送枪据为己有,于是把Normalgod扔进了一间实验室.这间实 ...
随机推荐
- 系统编程.py(多进程与多线程干货)
1.并发与并行* 多个任务轮换在CPU上跑叫并发* 多个任务在多个CPU上跑,没有交替执行的* 状态叫并行.通常情况下都是并发,即使是多核.* 而控制进程先执行谁后执行谁通过操作系统的调度算法.目前已 ...
- sublime3常用插件总结
本人之前使用的是webstorm,后来改用sublime,渐渐的爱上了它的快!(自行体会) 正式介绍sublime3常用的一些插件,安装流程不再赘述! SublimeTmpl 创建常用文件初始模板,必 ...
- MySQL数据库查看数据表占用空间大小和记录数
MySQL数据库中每个表占用的空间.表记录的行数的话,可以打开MySQL的 information_schema 数据库.在该库中有一个 TABLES 表,这个表主要字段分别是: TABLE_SCHE ...
- node、npm安装教程
描述: Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境.Node.js 使用了一个事件驱动.非阻塞式 I/O 的模型,使其轻量又高效. Node.js 的使用包 ...
- python mac下安装虚拟环境
Mac 下 Flask 框架 workon命令找不到 ---- 最终解决方案(详解具体实现操作过程中遇到的坑) Mac 下 Flask 的 全网最详细搭建 1.安装virtualenv和virtual ...
- Windows和Linux系统下,虚拟环境安装的全面说明和详细步骤
虚拟环境的创建和使用 用途: 1.在同一台电脑安装同一个包的不同版本 2.记录项目所用的所有的包的版本,方便部署. 如何使用: 1.创建虚拟环境 mkvirtualenv 虚拟环境名 -p pyt ...
- oracle监听配置
在listener.ora文件中指定监听的实例名和修改ip地址: 查看实例名:[localhost$] echo $ORACLE_SID LISTENER = (DESCRIPTION_LIST = ...
- 公用的cefsharp窗口
书接上回,.net实现一个nw,一个字,简单. 结构,无废话,上图. 要说这部分上回展示过的,大致结构如此,其实要说清楚结构,还是得从工作流程开始说起 流程 1.通过桌面的快捷方式启动WebOnDes ...
- 3 web服务器:静态文件
1.处理客户端请求数据 >>> s = "GET / HTTP/1.1\r\nHost: 127.0.0.1:8080\r\nConnection: keep-alive& ...
- javascript对象转为字符串
function getStringTime(time){ //年 year = time.getFullYear(); //月 month = time.getMonth() if(String(m ...