1. /*
  2. 题意:一个矩阵中有 n*m个宠物,每一个宠物都有一个状态, 1醒着的,0睡着的
  3. X离开的!如果这个宠物(醒着的)的周围醒着的个数>3 || <2它就会睡着,
  4. 如果这个宠物(睡着的)的周围醒着的个数==3就会醒来!
  5. 每一分钟都会有变换一个状态!
  6. 其中会有些宠物会在给定的时间内离开!
  7. */
  8. #include<iostream>
  9. #include<cstring>
  10. #include<cstdio>
  11. #include<algorithm>
  12. using namespace std;
  13.  
  14. int n, m, f, k;
  15.  
  16. char statu[][];
  17. int dir[][]={, , , , , -, -, , , , -, -, , -, -, };
  18. int cnt[][];//记录[i][j] 周围minions 醒着 的个数
  19.  
  20. int leave[][];
  21.  
  22. int main(){
  23. int t;
  24. scanf("%d", &t);
  25. while(t--){
  26. memset(leave, , sizeof(leave));
  27. scanf("%d%d%d%d", &n, &m, &f, &k);
  28. for(int i=; i<=n; ++i)
  29. scanf("%s", statu[i]+);
  30. while(k--){
  31. int u, v, z;
  32. scanf("%d%d%d", &z, &u, &v);//[u][v]这个宠物在z时间之后离开
  33. leave[u][v]=z;
  34. }
  35. memset(cnt, , sizeof(cnt));
  36. for(int tt=; tt<=f; ++tt){
  37. for(int i=; i<=n; ++i)
  38. for(int j=; j<=m; ++j){
  39. for(int k=; k<; ++k){
  40. int x=i+dir[k][];
  41. int y=j+dir[k][];
  42. if(x< || y< || x>n || y>m) continue;
  43. if(statu[x][y]=='') ++cnt[i][j];
  44. }
  45. }
  46. for(int i=; i<=n; ++i)
  47. for(int j=; j<=m; ++j){
  48. if(cnt[i][j]== && statu[i][j]=='')
  49. statu[i][j]='';
  50. else if((cnt[i][j]< || cnt[i][j]>) && statu[i][j]=='')
  51. statu[i][j]='';
  52.  
  53. if(leave[i][j]==tt) statu[i][j]='X';//该宠物到达时间后就会离开
  54. cnt[i][j]=;
  55. }
  56. }
  57. for(int i=; i<=n; ++i)
  58. printf("%s\n", statu[i]+);
  59. }
  60. return ;
  61. }

ZOJ 3804 YY's Minions (简单模拟)的更多相关文章

  1. ZOJ Problem Set - 3804 YY's Minions

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5336 比较简单的模拟题,题意也很好理解. #include <iostr ...

  2. tyvj 1027 木瓜地 简单模拟

    P1027 木瓜地 时间: 1000ms / 空间: 131072KiB / Java类名: Main 背景 USACO OCT09 4TH 描述 Bessie不小心游荡出Farmer John的田地 ...

  3. java web学习总结(二十二) -------------------简单模拟SpringMVC

    在Spring MVC中,将一个普通的java类标注上Controller注解之后,再将类中的方法使用RequestMapping注解标注,那么这个普通的java类就够处理Web请求,示例代码如下: ...

  4. WPF简单模拟QQ登录背景动画

    介绍 之所以说是简单模拟,是因为我不知道QQ登录背景动画是怎么实现的.这里是通过一些办法把它简化了,做成了类似的效果 效果图 大体思路 首先把背景看成是一个4行8列的点的阵距,X轴Y轴都是距离70.把 ...

  5. Linux 内核 链表 的简单模拟(2)

    接上一篇Linux 内核 链表 的简单模拟(1) 第五章:Linux内核链表的遍历 /** * list_for_each - iterate over a list * @pos: the & ...

  6. Linux 内核 链表 的简单模拟(1)

    第零章:扯扯淡 出一个有意思的题目:用一个宏定义FIND求一个结构体struct里某个变量相对struc的编移量,如 struct student { int a; //FIND(struct stu ...

  7. JavaWeb学习总结(四十九)——简单模拟Sping MVC

    在Spring MVC中,将一个普通的java类标注上Controller注解之后,再将类中的方法使用RequestMapping注解标注,那么这个普通的java类就够处理Web请求,示例代码如下: ...

  8. 简单模拟Hibernate的主要功能实现

    在学习期间接触到Hibernate框架,这是一款非常优秀的O/R映射框架,大大简化了在开发web项目过程中对数据库的操作.这里就简单模拟其底层的实现. /*******代码部分,及其主要注解***** ...

  9. 【HDU 4452 Running Rabbits】简单模拟

    两只兔子Tom和Jerry在一个n*n的格子区域跑,分别起始于(1,1)和(n,n),有各自的速度speed(格/小时).初始方向dir(E.N.W.S)和左转周期turn(小时/次). 各自每小时往 ...

随机推荐

  1. 《TCP/IP高效编程:改善网络程序的44个技巧》源码在Linux上的编译

    为了先完整编译通过,需要以下几个步骤: 1.进入linux子目录,执行 make.(此步骤为打补丁.) 2.返回上一级目录,打开文件 simplec.c,添加头文件 #include <stdi ...

  2. Python成长笔记 - 基础篇 (十一)----RabbitMQ、Redis 、线程queue

    本节内容: 1.RabbitMQ 消息队列 2.Redis 3.Mysql   PY 中的线程queue(threading Queue):用于多个线程之间进行数据交换,不能在进程间进行通信 进程qu ...

  3. 图解:Arcgis Server 安装

    必须保证IIS配置正常,否则arcserver安装不会成功. 选择安装路径,还是尽量不要在有括号的文件夹下. 设置服务名,最好使用默认的. 点击完成后会要求进行服务配置. 在windows serve ...

  4. ubuntu笔记

    安装包 sudo dpkg -i xxxx.deb 如果用户具有sudo权限,那么直接可以运行如下命令: #sudo su root #passwd #更改密码 或者直接运行sudo passwd r ...

  5. WPF,Silverlight与XAML读书笔记第四十六 - 外观效果之三皮肤与主题

    说明:本系列基本上是<WPF揭秘>的读书笔记.在结构安排与文章内容上参照<WPF揭秘>的编排,对内容进行了总结并加入一些个人理解. 皮肤 皮肤是应用程序中样式与模板的集合,可以 ...

  6. 基础调试命令 - wt (watch and trace)

    本文介绍windbg动态调试过程中一个非常有用的命令,wt的用法. wt命令 wt命令之所以称为wt是因为它是watch and trace的简称,即用来观察和跟踪的命令.这个命令一般用在动态调试而不 ...

  7. java生成压缩文件

    在工作过程中,需要将一个文件夹生成压缩文件,然后提供给用户下载.所以自己写了一个压缩文件的工具类.该工具类支持单个文件和文件夹压缩.放代码: import java.io.BufferedOutput ...

  8. Sublime Text 2—解决中文乱码

    Sublime Text 2是一个非常棒的代码及文本编辑器,绿色小巧.速度飞快,跨平台支持Win/Mac/Linux,支持32与64位,支持各种流行编程语言的语法高亮.代码补全等,有着许多其他编辑器没 ...

  9. 实战使用Axure设计App,使用WebStorm开发(4) – 实现页面UI

    系列文章 实战使用Axure设计App,使用WebStorm开发(1) – 用Axure描述需求  实战使用Axure设计App,使用WebStorm开发(2) – 创建 Ionic 项目   实战使 ...

  10. Robotium的左右为难 -- enterText

    最近测试框架收到反馈,详查后发现了一个Robotium的问题,甚有趣,遂记录. 问题场景: Robotium.enterText输入数据后,点击"发送"按钮,多数情况下失败,少数时 ...