题意:给出r*c的网格,有的网格为空。有的有水。再给出一个爆炸点,从这个点向四周爆出四个水滴,若碰到水则融为一体,若碰到其它水滴直接跑过去互不影响。每秒可跑一格,若水中水滴数量超过4则爆开。问T秒后网格的状态是如何的。

做法:因为数据有点多,直接用set优化bfs一次走一步的过程。变成一次走多步就可以。

#include<map>
#include<string>
#include<cstring>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<queue>
#include<vector>
#include<iostream>
#include<algorithm>
#include<bitset>
#include<climits>
#include<list>
#include<iomanip>
#include<stack>
#include<set>
using namespace std;
int num[110][110];
set<int>sr[110],sc[110];
int r,c,T;
bool beyond(int tr,int tc)
{
return tr<1||tc<1||tr>r||tc>c;
}
struct point
{
int tr,tc,flag;
point(){}
point(int tr,int tc,int flag)
{
this->tr=tr;
this->tc=tc;
this->flag=flag;
}
}hehe[110];
vector<point>bx;
bool vis[110][110];
void gao(int tr,int tc,int flag,int cnt)
{
if(!beyond(tr,tc)&&!vis[tr][tc])
{
if(num[tr][tc]>0)
{
num[tr][tc]++;
if(num[tr][tc]>4)
{
sr[tr].erase(tc);
sc[tc].erase(tr);
num[tr][tc]=-cnt;
bx.push_back(point(tr,tc,0));
vis[tr][tc]=1;
}
}
else
bx.push_back(point(tr,tc,flag));
}
}
void work()
{
set<int>::iterator it;
int cnt=0,p=0;
while(1)
{
int len=bx.size(),mn=INT_MAX;
if(p==len)
return;
for(int i=p;i<len;i++)
{
point t=bx[i];
int tr=t.tr,tc=t.tc,flag=t.flag;
if(flag==0||flag==1)
{
it=sc[tc].lower_bound(tr);
if(it!=sc[tc].begin())
{
it--;
mn=min(mn,tr-*it);
}
}
if(flag==0||flag==2)
{
it=sc[tc].upper_bound(tr);
if(it!=sc[tc].end())
mn=min(mn,*it-tr);
}
if(flag==0||flag==3)
{
it=sr[tr].lower_bound(tc);
if(it!=sr[tr].begin())
{
it--;
mn=min(mn,tc-*it);
}
}
if(flag==0||flag==4)
{
it=sr[tr].upper_bound(tc);
if(it!=sr[tr].end())
mn=min(mn,*it-tc);
}
}
if(cnt+mn>T)
return;
cnt+=mn;
memset(vis,0,sizeof(vis));
for(int i=p;i<len;i++)
{
point t=bx[i];
int tr=t.tr,tc=t.tc,flag=t.flag;
if(flag==0||flag==1)
{
tr-=mn;
gao(tr,tc,1,cnt);
tr+=mn;
}
if(flag==0||flag==2)
{
tr+=mn;
gao(tr,tc,2,cnt);
tr-=mn;
}
if(flag==0||flag==3)
{
tc-=mn;
gao(tr,tc,3,cnt);
tc+=mn;
}
if(flag==0||flag==4)
{
tc+=mn;
gao(tr,tc,4,cnt);
tc-=mn;
}
}
p=len;
}
}
int main()
{
int n;
while(scanf("%d%d%d%d",&r,&c,&n,&T)!=EOF)
{
for(int i=1;i<=r;i++)
sr[i].clear();
for(int i=1;i<=c;i++)
sc[i].clear();
memset(num,0,sizeof(num));
for(int i=0;i<n;i++)
{
int t;
scanf("%d%d%d",&hehe[i].tr,&hehe[i].tc,&t);
sr[hehe[i].tr].insert(hehe[i].tc);
sc[hehe[i].tc].insert(hehe[i].tr);
num[hehe[i].tr][hehe[i].tc]=t;
}
int tr,tc;
scanf("%d%d",&tr,&tc);
bx.clear();
bx.push_back(point(tr,tc,0));
work();
for(int i=0;i<n;i++)
{
tr=hehe[i].tr;
tc=hehe[i].tc;
int t=num[tr][tc];
if(t<0)
printf("0 %d\n",-t);
else
printf("1 %d\n",t);
}
}
}

Time Limit: 3000/1500 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)

Total Submission(s): 414    Accepted Submission(s): 101

Problem Description
XYZ is playing an interesting game called "drops". It is played on a r∗c grid.
Each grid cell is either empty, or occupied by a waterdrop. Each waterdrop has a property "size". The waterdrop cracks when its size is larger than 4, and produces 4 small drops moving towards 4 different directions (up, down, left and right). 



In every second, every small drop moves to the next cell of its direction. It is possible that multiple small drops can be at same cell, and they won't collide. Then for each cell occupied by a waterdrop, the waterdrop's size increases by the number of the
small drops in this cell, and these small drops disappears. 



You are given a game and a position (x, y),
before the first second there is a waterdrop cracking at position (x, y).
XYZ wants to know each waterdrop's status after T seconds,
can you help him?



1≤r≤100, 1≤c≤100, 1≤n≤100, 1≤T≤10000
 
Input
The first line contains four integers r, c, n and T. n stands
for the numbers of waterdrops at the beginning. 

Each line of the following n lines
contains three integers xi, yi, sizei,
meaning that the i-th
waterdrop is at position (xi, yi)
and its size is sizei.
(1≤sizei≤4)

The next line contains two integers x, y. 



It is guaranteed that all the positions in the input are distinct. 



Multiple test cases (about 100 cases), please read until EOF (End Of File).
 
Output
n lines.
Each line contains two integers Ai, Bi: 

If the i-th
waterdrop cracks in T seconds, Ai=0, Bi= the
time when it cracked. 

If the i-th
waterdrop doesn't crack in T seconds, Ai=1, Bi= its
size after T seconds.
 
Sample Input
4 4 5 10
2 1 4
2 3 3
2 4 4
3 1 2
4 3 4
4 4
 
Sample Output
0 5
0 3
0 2
1 3
0 1
 
Author
XJZX
 
Source

hdu5336XYZ and Drops的更多相关文章

  1. HDU5336-XYZ and Drops-模拟

    模拟水珠那个游戏. 小水珠超过边界会消失. 会有两个水珠同时到达一个size=4大水珠的情况.要移动完统一爆炸 #include <vector> #include <cstdio& ...

  2. HDU 5336 XYZ and Drops

    Problem Description XYZ is playing an interesting game called "drops". It is played on a r ...

  3. HDU 5336——XYZ and Drops——————【广搜BFS】

    XYZ and Drops Time Limit: 3000/1500 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Tot ...

  4. Hdu 5336 XYZ and Drops (bfs 模拟)

    题目链接: Hdu 5336 XYZ and Drops 题目描述: 有一个n*m的格子矩阵,在一些小格子里面可能会有一些水珠,每个小水珠都有一个size.现在呢,游戏开始咯,在一个指定的空的小格子里 ...

  5. 2015 Multi-University Training Contest 4 hdu 5336 XYZ and Drops

    XYZ and Drops Time Limit: 3000/1500 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Tot ...

  6. Huge Packet Drops (Tx drops) Observed on NetScaler

    Huge Packet Drops (Tx drops) Observed on NetScaler 来源  https://support.citrix.com/article/CTX215843 ...

  7. Django Drops

    1.Django Intro 2.Django Install (1) PIP安装 sudo apt-get isntall python-pip sudo pip install Django (2 ...

  8. HDU 5336 XYZ and Drops 2015 Multi-University Training Contest 4 1010

    这题的题意是给你一幅图,图里面有水滴.每一个水滴都有质量,然后再给你一个起点,他会在一開始的时候向四周发射4个小水滴,假设小水滴撞上水滴,那么他们会融合,假设质量大于4了,那么就会爆炸,向四周射出质量 ...

  9. 全网最全乌云drops文章下载(epub)

    前几天搞得epub格式的,为了方便kindle才做的,没想到站关了. 链接: http://pan.baidu.com/s/1eRIoJC2 密码: b6aq

随机推荐

  1. 1,http协议的细节部分学习

    http协议(80端口)https(443端口) 主要是一直对三次握手模模糊糊,并且抓包的时候不知道那些Accept.User-Agent什么意思,就仔细找课程学了一下. 学习简介: 1,涉及工具(w ...

  2. SpringBoot学习笔记(10)-----SpringBoot中使用Redis/Mongodb和缓存Ehcache缓存和redis缓存

    1. 使用Redis 在使用redis之前,首先要保证安装或有redis的服务器,接下就是引入redis依赖. pom.xml文件如下 <dependency> <groupId&g ...

  3. LA3231 Fair Share 二分_网络流

    Code: #include<cstdio> #include<vector> #include<queue> #include<cstring> #i ...

  4. NodeJS学习笔记 (5)网络服务-http-req(ok)

    原文:https://github.com/chyingp/nodejs-learning-guide 自己敲代码: 概览 本文的重点会放在req这个对象上.前面已经提到,它其实是http.Incom ...

  5. Microsoft Visual Studio 2015打开TFS大量报错问题解决方案

    用vs2015打开项目出现如图错误,尝试对XX项执行 添加 操作时遇到 XX 个错误,因为公司项目比较大,这个错误一直在弹,搜索了下,没有找到出现类似问题的解决方案. 因为这个路径是TFS(Team ...

  6. linux 空间不够了 修改 /boot

    1>  查看空间多少:df -h2>  查看当期内核: uname -r3>  查找内核   rpm -qa | grep kernel4>  删除多余的内核 yum remo ...

  7. 2019年北航OO第三单元(JML规格任务)总结

    一.JML简介 1.1 JML与契约式设计 说起JML,就不得不提到契约式设计(Design by Contract).这种设计模式的始祖是1986年的Eiffel语言.它是一种限定了软件中每个元素所 ...

  8. C++ Primer笔记13_运算符重载_总结

    总结: 1.不能重载的运算符: . 和 .* 和 ?: 和 ::  和 sizeof 和 typeid 2.重载运算符有两种基本选择: 类的成员函数或者友元函数, 建议规则例如以下: 运算符 建议使用 ...

  9. Python 入门学习 -----变量及基础类型(元组,列表,字典,集合)

    Python的变量和数据类型 1 .python的变量是不须要事先定义数据类型的.能够动态的改变 2. Python其中一切皆对象,变量也是一个对象,有自己的属性和方法 我们能够通过 来查看变量的类型 ...

  10. sass07 函数

    scsss @function double($width){ //自定义函数u @return $width * 2; } @function double($width){ //自定义函数u @i ...