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 塌陷的牧场】的更多相关文章

  1. bzoj5048: 塌陷的牧场

    Description 农夫小Q将他的奶牛们饲养在一个长n宽m的矩形网格牧场中.行从上到下依次编号为1到n,列从左往右依次编号为1 到m.为了防止奶牛们逃跑,小Q在牧场外圈安装了一排电网,只要奶牛走出 ...

  2. bzoj 1602 [Usaco2008 Oct]牧场行走(LCA模板)

    1602: [Usaco2008 Oct]牧场行走 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 379  Solved: 216[Submit][Sta ...

  3. BZOJ 1602: [Usaco2008 Oct]牧场行走( 最短路 )

    一棵树..或许用LCA比较好吧...但是我懒...写了个dijkstra也过了.. ---------------------------------------------------------- ...

  4. LCA || BZOJ 1602: [Usaco2008 Oct]牧场行走 || Luogu P2912 [USACO08OCT]牧场散步Pasture Walking

    题面:[USACO08OCT]牧场散步Pasture Walking 题解:LCA模版题 代码: #include<cstdio> #include<cstring> #inc ...

  5. BZOJ 1602: [Usaco2008 Oct]牧场行走 倍增裸题

    Description N头牛(2<=n<=1000)别人被标记为1到n,在同样被标记1到n的n块土地上吃草,第i头牛在第i块牧场吃草. 这n块土地被n-1条边连接. 奶牛可以在边上行走, ...

  6. 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 ...

  7. BZOJ 1602 USACO2008 Oct 牧场行走

    翻翻吴大神的刷题记录翻到的... 乍一看是一个树链剖分吓瓜我...难不成吴大神14-10-28就会了树剖?orz... 再一看SB暴力都可过... 然后一看直接树上倍增码个就好了... 人生真是充满着 ...

  8. WOJ 39 塌陷的牧场

    感觉……做克老师的题,都很神仙…… 还有去年一个人坐在家里写挂60分算法的惨痛记忆,凭借着一点点记忆重新写这道题. 感觉这并查集真的很神仙,仍然不会算最后的α的复杂度……自己想感觉无论如何都要挂个lo ...

  9. BZOJ 1602 [Usaco2008 Oct]牧场行走 dfs

    题意:id=1602">链接 方法:深搜暴力 解析: 这题刚看完还有点意思,没看范围前想了想树形DP,只是随便画个图看出来是没法DP的,所以去看范围. woc我没看错范围?果断n^2暴 ...

随机推荐

  1. jstree 全部选中事件 select_all 使用

    select_all function of jstree not checked node for jstree-open branch of ajax-jstree 很尴尬啊,找了整个百度,360 ...

  2. Nagios 监控Windows服务器(详细篇)

    1. 监控内容 windows服务器的内部参数包括以下 a. 内存使用状况 b. CPU负载 c. 磁盘使用状况 d. 服务状态 e. 运行的进程 2. 监控原理 在windows服务器内安装NSCl ...

  3. Docker自学纪实(三)Docker容器数据持久化

    谈起数据卷 我一直觉得是个枯燥无聊的话题 但是通过今天的实操和阅读 我发现其实并不是 其实就像走夜路 没有光明,第一次都是恐惧 但是如果走的次数多了 或者静下心来去克制恐惧 也许就会驾轻就熟或者等到黎 ...

  4. 如何解决mysql中读取含表情符号的内容无法识别的问题

    当内容中包含有表情符号的时候,写入mysql时一般会设置字段或者表的charset为utf8mb4的形式: ) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicod ...

  5. Fiddler(一)

    Fiddler:学习scrapy,不只是满足于网页上爬去信息的成功乐趣,现在开始接触爬去手机信息了,不好解决,知道过程不会轻松,但自己想去尝试.QAQ 写这篇博客是基于以下的几位大神学习笔记,我只是做 ...

  6. 内置函数系列之 sorted排序

    sorted排序函数语法: sorted(可迭代对象,key=函数(默认为None),reverse=False) 将可 迭代对象的每一个元素传进key后面的函数中,根据函数运算的结果(返回值)进行排 ...

  7. PHP获取异常信息

    try { } catch (\Exception $e) { $extra = [ 'code' => $e->getCode(), 'msg' => $e->getMess ...

  8. composer安装教程(Linux版)

    composer 是款不错的工具,那么如何进行安装composer呢 如果您是linux系统或是mac系统 请先确定是否安装了curl linux安装curl   1 yum install -y c ...

  9. urllib使用四--urlencode,urlparse,

    urllib.urlencode 把字典数据转换为URL编码 # -*- coding: cp936 -*- import urllib params = {'score':100,'name':'爬 ...

  10. 基于原版Hadoop的YDB部署(转)

    YDB依赖环境准备 一.硬件环境 硬件如何搭配,能做到比较高的性价比,不存在短板.合理的硬件搭配,对系统的稳定性也很关键. 1.CPU不是核数越高越好,性价比才是关键. 经常遇到很多的企业级客户,他们 ...