【BZOJ 5048 塌陷的牧场】
Time Limit: 25 Sec Memory Limit: 256 MB
Submit: 77 Solved: 34
[Submit][Status][Discuss]
Description
农夫小Q将他的奶牛们饲养在一个长n宽m的矩形网格牧场中。行从上到下依次编号为1到n,列从左往右依次编号为1
到m。为了防止奶牛们逃跑,小Q在牧场外圈安装了一排电网,只要奶牛走出这个n*m的矩形,就会触电死去。在牧
场中,有e个格子塌陷了,一旦奶牛踩在上面,就会掉下去摔死。小Q为了饲养尽可能多的奶牛,在每个没有塌陷的
格子上,都饲养着一头奶牛。tangjz偷走了小Q的口哨,并用口哨向奶牛们依次施放了q条指令,每条指令包含两个
参数d和k,d表示上下左右之一的方向,k表示前进步数。发出指令后,每头奶牛都会听话地执行指令,甚至会因此
丧生。所有奶牛移动完毕之后,tangjz才会施放下一条指令。请写一个程序统计每条指令中小Q损失了多少头奶牛
Input
第一行包含4个正整数n,m,e,q(1<=n,m,q<=2000,0<=e<=min(nm,2000))
分别表示牧场的长宽、塌陷的格子数以及指令数。
接下来e行,每行两个正整数x_i,y_i(1<=x_i<=n,1<=y_i<=m)
表示每个塌陷格子的坐标。输入数据保证每个格子不会被描述多次。
接下来q行,每行包含一个字符d和一个正整数k(1<=k<=2000)
描述每条指令。其中UDLR分别表示上下左右。
Output
输出q行,每行一个整数,即第i条指令中损失的奶牛数量。
Sample Input
3 5 3 4
1 4
2 2
3 3
R 2
L 1
D 2
U 1
Sample Output
10
0
2
0
题解:
①观察数据发现障碍物非常少,不超过2000,因此将移动牛反过来换成移动障碍物。
②但是每次移动每个障碍物并杀死牛这种暴力时间复杂度为:O(n3),需要优化:
③使用链表优化,分别表示四个方向上指向的最近的没有被杀死的牛的位置。
④链表的实现有的人说是并查集……QAQ
#include<cstdio>
#define Fa fa[_]
#define go(i,a,b) for(int i=a;i<=b;i++)
const int N=2003;struct P{int x,y;}a[10010];
int n,m,e,q,ans,k,fa[5][N][N],_;bool dead[N][N];char c;
void Kill(int x,int y)
{
if(dead[x][y])return;ans+=(dead[x][y]=1);
fa[0][x][y]--;fa[1][x][y]++;fa[2][x][y]--;fa[3][x][y]++;
}
int find01(int x,int y){return Fa[x][y]==x?x:Fa[x][y]=find01(Fa[x][y],y);}
int find23(int x,int y){return Fa[x][y]==y?y:Fa[x][y]=find23(x,Fa[x][y]);} void Up(){_=0;go(i,1,e)
{
int x=a[i].x,y=a[i].y;a[i].x-=k;
if(y<1||y>m||x<1)continue;if(x>n)x=n;
while((x=find01(x,y))>=1&&x>=a[i].x)Kill(x,y);
}
}
void Down(){_=1;go(i,1,e)
{
int x=a[i].x,y=a[i].y;a[i].x+=k;
if(y<1||y>m||x>n)continue;if(x<1)x=1;
while((x=find01(x,y))<=n&&x<=a[i].x)Kill(x,y);
}
}
void Left(){_=2;go(i,1,e)
{
int x=a[i].x,y=a[i].y;a[i].y-=k;
if(x<1||x>n||y<1)continue;if(y>m)y=m;
while((y=find23(x,y))>=1&&y>=a[i].y)Kill(x,y);
}
}
void Right(){_=3;go(i,1,e)
{
int x=a[i].x,y=a[i].y;a[i].y+=k;
if(x<1||x>n||y>m)continue;if(y<1)y=1;
while((y=find23(x,y))<=m&&y<=a[i].y)Kill(x,y);
}
}
int main()
{
scanf("%d%d%d%d",&n,&m,&e,&q);
go(i,0,n+1)go(j,0,m+1)fa[0][i][j]=fa[1][i][j]=i,fa[2][i][j]=fa[3][i][j]=j;
go(i,1,e)scanf("%d %d",&a[i].x,&a[i].y),Kill(a[i].x,a[i].y);
go(i,1,n)a[++e].x=i,a[e].y=0,a[++e].x=i,a[e].y=m+1;
go(i,1,m)a[++e].x=0,a[e].y=i,a[++e].x=n+1,a[e].y=i;
while(ans=0,q--&&scanf(" %c%d",&c,&k))
{
c=='U'?Down(),1:1,c=='D'?Up(),1:1,c=='R'?Left(),1:1,c=='L'?Right(),1:1;
printf("%d\n",ans);
}return 0;
}//Paul_Guderian
回首往事我明白了他曾叮咛的,所有那些平淡无味的话语.
那年我五岁,爸爸对我说,学一点东西,否则你会一事无成。————汪峰《那年我五岁》
【BZOJ 5048 塌陷的牧场】的更多相关文章
- bzoj5048: 塌陷的牧场
Description 农夫小Q将他的奶牛们饲养在一个长n宽m的矩形网格牧场中.行从上到下依次编号为1到n,列从左往右依次编号为1 到m.为了防止奶牛们逃跑,小Q在牧场外圈安装了一排电网,只要奶牛走出 ...
- bzoj 1602 [Usaco2008 Oct]牧场行走(LCA模板)
1602: [Usaco2008 Oct]牧场行走 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 379 Solved: 216[Submit][Sta ...
- BZOJ 1602: [Usaco2008 Oct]牧场行走( 最短路 )
一棵树..或许用LCA比较好吧...但是我懒...写了个dijkstra也过了.. ---------------------------------------------------------- ...
- LCA || BZOJ 1602: [Usaco2008 Oct]牧场行走 || Luogu P2912 [USACO08OCT]牧场散步Pasture Walking
题面:[USACO08OCT]牧场散步Pasture Walking 题解:LCA模版题 代码: #include<cstdio> #include<cstring> #inc ...
- BZOJ 1602: [Usaco2008 Oct]牧场行走 倍增裸题
Description N头牛(2<=n<=1000)别人被标记为1到n,在同样被标记1到n的n块土地上吃草,第i头牛在第i块牧场吃草. 这n块土地被n-1条边连接. 奶牛可以在边上行走, ...
- BZOJ——1602: [Usaco2008 Oct]牧场行走 || 洛谷—— P2912 [USACO08OCT]牧场散步Pasture Walking
http://www.lydsy.com/JudgeOnline/problem.php?id=1602 || https://www.luogu.org/problem/show?pid=2912 ...
- BZOJ 1602 USACO2008 Oct 牧场行走
翻翻吴大神的刷题记录翻到的... 乍一看是一个树链剖分吓瓜我...难不成吴大神14-10-28就会了树剖?orz... 再一看SB暴力都可过... 然后一看直接树上倍增码个就好了... 人生真是充满着 ...
- WOJ 39 塌陷的牧场
感觉……做克老师的题,都很神仙…… 还有去年一个人坐在家里写挂60分算法的惨痛记忆,凭借着一点点记忆重新写这道题. 感觉这并查集真的很神仙,仍然不会算最后的α的复杂度……自己想感觉无论如何都要挂个lo ...
- BZOJ 1602 [Usaco2008 Oct]牧场行走 dfs
题意:id=1602">链接 方法:深搜暴力 解析: 这题刚看完还有点意思,没看范围前想了想树形DP,只是随便画个图看出来是没法DP的,所以去看范围. woc我没看错范围?果断n^2暴 ...
随机推荐
- Mysql5.7.25在windows下安装
在网上看到了很多安装方法,也试了很多,md,网上资源多了也是有各种坑,这里只说在windows下安装mysql5.7.25 一.下载安装包 链接:https://dev.mysql.com/downl ...
- 差点掉坑,MySQL一致性读原来是有条件的
众所周知,在设定了隔离等级为Repeatable Read及以上时,InnoDB 可以实现数据的一致性读.换句话来说,就是事务执行的任意时刻,读取到的数据是同一个快照,不会受到其他事务的更新影响. 以 ...
- my share
网盘一: username:3a1bd0f6634d72a0423aa21c7d2dee1a password:adaa0dfa36f537a4469fcc6e78823e1c 网盘二: userna ...
- 关于对GitHub的使用
什么是GitHub? GitHub是版本控制和协作的代码托管平台.它可以让你在其他人在任何地方一起工作. 本文主要向您介绍GitHub essentials,如存储库,分支,提交和合并请求.将您创建自 ...
- SQL tp3.2 批量更新 saveAll
/** * 批量更新数据 * @param [array] $datas [更新数据] * @param [string] $table_name [表名] */ public function sa ...
- kivy学习二:做一个查询所在地区身份证前6位的小软件
经过半个月的尝试,终于成功,记录下来备查! 做完之后发现有很多的问题没有解决,请大佬多批评指教! 强烈建议:学习KIVY的查看官方文档 需要用的知识: 1.字典的相关知识 2.kivy的下拉列表(Dr ...
- 第三章:Web表单
感谢作者 –> 原文链接 本文翻译自 The Flask Mega-Tutorial Part III: Web Forms 这是Flask Mega-Tutorial系列的第三部分,我将告诉你 ...
- 全方位认识HDMI接口技术
HDMI接口并不是一个开放的标准.制造商必须向HDMI标准制定协会支付版税,来换取一个生产许可证.不过这个版税可不便宜,每年要交纳15000美元的许可费,并且更黑的是每生产一个HDMI接口就要支付0. ...
- Centos7 查看Mysql配置文件
my.cnf是mysql启动时加载的配置文件,一般会放在mysql的安装目录中,用户也可以放在其他目录加载. 安装mysql后,系统中会有多个my.cnf文件,有些是用于测试的. 使用locate m ...
- 剑指Offer - 九度1350 - 二叉树的深度
剑指Offer - 九度1350 - 二叉树的深度2013-11-23 00:54 题目描述: 输入一棵二叉树,求该树的深度.从根结点到叶结点依次经过的结点(含根.叶结点)形成树的一条路径,最长路径的 ...