CF1335F Robots on a Grid
比较简单的倍增
但还是看了题解才会
题意
给出一个 \(n\times m\) 的网格,每个格子有颜色,\(0\) 黑 \(1\) 白,每个格子还有一个方向,表示这个格子上的机器人会向那个方向走,并保证不会走出格子
摆放机器人,它们同时开始运动,在任意时刻不能有两个机器人在同一个格子里
先最大化机器人个数,如果多种方案机器人个数相等,再最大化摆在黑格子里的机器人数量
首先,这个路线肯定是循环的,如果不循环,就会走到无限多个格子,不合理
然后,对于任意一个格子,从那里开始走到完成一个完整的循环,步数肯定小于等于 \(nm\),显然它不能走了比 \(nm\) 还多的格子仍然不开始循环
而对于两个不同的循环,它们一定没有交点(就是一个相同的格子),如果有,肯定就不会行成两个循环了
如果有两个机器人分别走了至少 \(nm\) 步,那么它们肯定已经各子循环了一次或以上了
所以,如果它们不在同一个循环,显然不会相遇
如果在一个循环,且没有在 \(nm\) 步内相遇,说明这时它们已经“同步”了,就是会一直保持这一个距离不断的走,永不相遇
当然,如果在 \(nm\) 步之前就已经相遇,那么它们会一直一起走,不会有影响
至此,我们判断两个格子上的机器人是否会相遇的方法,就是看它们走了 \(nm\) 步以后,是不是在同一个格子
所以,假设我们在所有格子都摆上机器人,让他们走,一旦有几个相遇了,就说明我们要去掉这些机器人只剩下其中的一个
这时,给这 \(nm\) 个点编号 \(1\ldots nm\),并用\(white_i,black_i\)表示的分别是有没有从白/黑格出发的机器人,\(nm\) 格后会走到这里
然后从 \(1\) 到 \(nm\) 统计答案,如果某个格子可以由黑色格子中的机器人走来,就保留黑色格子的那个,否则任意保留
就可以计算出答案了
对于走 \(nm\) 步那个操作,就要用倍增实现
#include<cstdio>
#include<algorithm>
#include<iostream>
#include<cmath>
#include<map>
#include<iomanip>
#include<cstring>
#define reg register
#define EN std::puts("")
#define LL long long
inline int read(){
register int x=0;register int y=1;
register char c=std::getchar();
while(c<'0'||c>'9'){if(c=='-') y=0;c=std::getchar();}
while(c>='0'&&c<='9'){x=x*10+(c^48);c=std::getchar();}
return y?x:-x;
}
int black[1000006],white[1000005];
int nex[24][1000006];
int color[1000006];
char s[1000006];
int main(){int T=read();while(T--){
int n=read(),m=read();
for(reg int i=1;i<=n;i++){
std::scanf("%s",s+1);
for(reg int j=1;j<=m;j++) color[(i-1)*m+j]=s[j]=='0'?0:1;
}
for(reg int i=1;i<=n;i++){
std::scanf("%s",s+1);
for(reg int j=1;j<=m;j++){
int now=(i-1)*m+j;
if(s[j]=='U') nex[0][now]=now-m;
else if(s[j]=='D') nex[0][now]=now+m;
else if(s[j]=='L') nex[0][now]=now-1;
else nex[0][now]=now+1;
}
}
n*=m;
for(reg int i=1;i<=20;i++)
for(reg int j=1;j<=n;j++) nex[i][j]=nex[i-1][nex[i-1][j]];
for(reg int j=1;j<=n;j++){
int to=j;
for(reg int i=20;~i;i--){//倒着循环,倍增传统套路,不过想想也能知道,要先走大的步数
if((1<<i)&n) to=nex[i][to];
}
color[j]?white[to]=1:black[to]=1;
}
int ans=0,black_num=0;
for(reg int i=1;i<=n;i++)
if(black[i]) black_num++,ans++,black[i]=white[i]=0;
else if(white[i]) ans++,black[i]=white[i]=0;
std::printf("%d %d\n",ans,black_num);
}
return 0;
}
CF1335F Robots on a Grid的更多相关文章
- Robots on a grid(DP+bfs())
链接:http://www.bnuoj.com/bnuoj/problem_show.php?pid=25585 Current Server Time: 2013-08-27 20:42:26 Ro ...
- Map-making Robots: A Review of the Occupancy Grid Map Algorithm
栅格地图算法:http://www.ikaros-project.org/articles/2008/gridmaps/
- WPF Wonders: Transformations (and Robots!)
indows Presentation Framework (WPF) gets a lot of mileage out of being layered on top of DirectX, in ...
- POJ 1548 Robots (Dilworth)
Robots Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 3621 Accepted: 1643 Description Yo ...
- hdu6229 Wandering Robots 2017沈阳区域赛M题 思维加map
题目传送门 题目大意: 给出一张n*n的图,机器人在一秒钟内任一格子上都可以有五种操作,上下左右或者停顿,(不能出边界,不能碰到障碍物).题目给出k个障碍物,但保证没有障碍物的地方是强联通的,问经过无 ...
- CH6802 車的放置 和 CH6B24 Place the Robots
6802 車的放置 0x60「图论」例题 描述 给定一个N行M列的棋盘,已知某些格子禁止放置.问棋盘上最多能放多少个不能互相攻击的車.車放在格子里,攻击范围与中国象棋的"車"一致. ...
- ZOJ 1654 Place the Robots(最大匹配)
Robert is a famous engineer. One day he was given a task by his boss. The background of the task was ...
- ZOJ 1654--Place the Robots【二分匹配 && 经典建图】
Place the Robots Time Limit: 5 Seconds Memory Limit: 32768 KB Robert is a famous engineer. One ...
- gym 100971 J Robots at Warehouse
Vitaly works at the warehouse. The warehouse can be represented as a grid of n × m cells, each of wh ...
随机推荐
- C/C++内存详解
众所周知,堆和栈是数据结构中的两种数据结构类型,堆是一种具有优先顺序的完全二叉树(或者说是一种优先队列,因为它在一定的优先顺序下满足队列先进先出的特点),排队打饭就是它的典型实例,栈是一种后进先出的数 ...
- Flask 入门(一)(Mac 系统)
熟话说,万事开头难,为了运行这第一个程序,我可是碰了不少壁,接下来我将正确的方法交给大家. 1.首先得有python和虚拟环境 (1)python环境苹果系统自带 (2)虚拟环境: 安装virtual ...
- PTA 6-1 单链表逆转
本题是一个非常经典的题目:单链表逆转. 这是链表结点的定义: typedef struct Node *PtrToNode; struct Node { ElementType Data; /* 存储 ...
- python10
一.多进程multiprocessing multiprocessing包是Python中的多进程管理包.与threading.Thread类似,它可以利用multiprocessing.Proce ...
- 22.1 Extends 继承的 方法重写、@Override的使用、
/* * 继承中成员方法的特点 * 子类中没有这个方法,调用父类的 * 子类中重写了这个方法,调用子类的 * 方法的重写:在子父类当中,子类的方法和父类的完全一样,子类重写了父类的方法(覆盖),当子类 ...
- Docker命名空间
命名空间 命名空间( namespace )是 Linux 内核的一个强大特性,为容器虚拟化的实现带来极大便利,利用这 特性,每个容器都可以拥有自己单独的命名空间,运行在其中的应用都像是在独立的操作系 ...
- std::string 字符串分割
#include <iostream> #include <string> #include <vector> std::vector<std::string ...
- Spring Cloud 系列之 Gateway 服务网关(一)
什么是 Spring Cloud Gateway Spring Cloud Gateway 作为 Spring Cloud 生态系统中的网关,目标是替代 Netflix Zuul,其不仅提供统一的路由 ...
- 使用python pip安装工具组件包:出现 requests File “<stdin>",line 1 pip install xxx ^ SyntaxError:invalid syntax
最近想要试试python ,软件安装完成了,但是,import 组件包时,出了问题,一直不得解:安装pycharm 工具感觉麻烦,不想安装那些,只想单纯使用python . 问题复现: 1.Windo ...
- L14梯度消失、梯度爆炸
梯度消失.梯度爆炸以及Kaggle房价预测 梯度消失和梯度爆炸 考虑到环境因素的其他问题 Kaggle房价预测 梯度消失和梯度爆炸 深度模型有关数值稳定性的典型问题是消失(vanishing)和爆炸( ...