Description

下图是一个由容器和管道组成的排水系统。对于这个系统,\(Slavko\) 想知道如果一直向容器1灌水,那么所有容器从空到充满水的顺序。

系统共有 \(K\) 个容器标号为1到 \(K\) 。整个系统可以用 \(N\) 行 \(M\) 列的字符矩阵描述。所有容器都是矩形的,容器和管道的边界用下列字符表示:

‘-’:表示边界的水平部分

‘|’:表示边界的垂直部分

‘+’:表示边界的顶点,即水平与垂直部分的交界点。特别的,容器与管道的交接点使用容器边界的表示字符。

每个容器内部,存在某个位置开始的一串数字表示容器编号,而其它位置都由‘.’表示。例如,标号12的容器内部会出现”12”。

对于除了容器1以外的所有容器,有且仅有一个供水管道从容器上方边界进入。容器1没有供水管道。

每个容器可以有0到多个排水管道从侧面边界连出。同一容器的多个排水管道一定具有不同的高度(即从矩阵不同的行连出)。

每个管道直接连接两个容器,多个管道之间不会相交。每条管道中的水从源容器径直流向目标容器,且管道路线只会向同一行或者下一行延伸。亦即,管道下降后不会再回到之前经过的行。

进入的水在容器中不断积累直到充满容器。在此过程中,如果水面到达容器某个排水管道的高度,接下来的水会从管道流出直到管道填满。

请你帮助 \(Slavko\) 找出容器被灌满的顺序。

注:测试数据保证每个‘+’的上下左右都是一个‘|’、一个‘-’和两个‘.’组成,而且管道只与进入和排出的容器相邻,进入时连接字符为‘|’,排出时连接字符为‘-’。

Input

第一行为两个整数 \(N\)、\(M\)。

接下来 \(N\) 行,每行 \(M\) 个字符,为表示系统的矩阵。

Output

请你输出 \(K\) 行,第 \(i\) 行为第 \(i\) 个被水填满的容器编号。数据保证顺序唯一。

Sample Input

12 13

..+--+.......

+-|..|.......

|.|.1|--+....

|.+--+..|....

|......+----+

+---+..|..2.|

....|..+----+

.+--+........

.|...........

+---+........

|.3.|........

+---+........

Sample Output

2

3

1

HINT

样例解释:从容器1开始灌水。水面到达高度1时,开始从管道流向容器2。容器2灌满以后,容器1的水面开始继续上升,直到到达高度2,此时开始从管道流向容器3。容器3灌满以后,容器1的水面继续上升直到灌满容器。

【数据规模与约定】

对于 \(70%\) 的数据,\(1 \leq N, M \leq 100\)。

对于 \(100%\) 的数据,\(1 \leq N, M \leq 1000\)。

来源:\(NOI2019\) 北京队集训


想法

第一眼看题没懂,感觉好怕怕

后来再看,就是个大模拟。写完还挺有成就感【捂脸】


代码

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<algorithm>
  4. using namespace std;
  5. const int N = 1005;
  6. int n,m;
  7. char mp[N][N];
  8. int be[N][N];
  9. struct con{
  10. int l,r,u,d;
  11. }d[N*N];
  12. int k;
  13. void get_con(int x,int y,int id){
  14. int i=x,j=y;
  15. while(mp[i][j]!='|') j--; d[id].l=j;
  16. j=y;
  17. while(mp[i][j]!='|') j++; d[id].r=j;
  18. j=y;
  19. while(mp[i][j]!='-') i--; d[id].u=i;
  20. i=x;
  21. while(mp[i][j]!='-') i++; d[id].d=i;
  22. for(j=d[id].l;j<=d[id].r;j++) be[d[id].u][j]=id;
  23. }
  24. int find(int x,int y,int dir){
  25. while(!be[x][y]){
  26. if(mp[x][y]=='-'){
  27. if(dir==3) y--;
  28. else y++;
  29. }
  30. else if(mp[x][y]=='|') {
  31. if(dir==0) x--;
  32. else x++;
  33. }
  34. else{
  35. if(dir==3 || dir==1){
  36. if(x>0 && mp[x-1][y]=='|') x--,dir=0;
  37. else x++,dir=2;
  38. }
  39. else{
  40. if(y>0 && mp[x][y-1]=='-') y--,dir=3;
  41. else y++,dir=1;
  42. }
  43. }
  44. }
  45. return be[x][y];
  46. }
  47. void dfs(int u){
  48. int v;
  49. for(int i=d[u].d;i>=d[u].u;i--){
  50. v=0;
  51. if(d[u].l>0 && mp[i][d[u].l-1]=='-') v=find(i,d[u].l-1,3);
  52. if(d[u].r<m-1 && mp[i][d[u].r+1]=='-') v=find(i,d[u].r+1,1);
  53. if(v) dfs(v);
  54. }
  55. printf("%d\n",u);
  56. }
  57. int main()
  58. {
  59. scanf("%d%d",&n,&m);
  60. for(int i=0;i<n;i++) scanf("%s",mp[i]);
  61. //find con
  62. int x;
  63. for(int i=0;i<n;i++)
  64. for(int j=0;j<m;j++){
  65. if(!isdigit(mp[i][j])) continue;
  66. x=mp[i][j] -'0';
  67. while(j+1<m && isdigit(mp[i][j+1])) x=x*10+mp[i][++j]-'0';
  68. k=max(k,x);
  69. get_con(i,j,x);
  70. }
  71. dfs(1);
  72. return 0;
  73. }

[洛谷 P5053] [COCI2017-2018#7] Clickbait的更多相关文章

  1. LOJ 2743(洛谷 4365) 「九省联考 2018」秘密袭击——整体DP+插值思想

    题目:https://loj.ac/problem/2473 https://www.luogu.org/problemnew/show/P4365 参考:https://blog.csdn.net/ ...

  2. 洛谷P4382 [八省联考2018]劈配(网络流,二分答案)

    洛谷题目传送门 说不定比官方sol里的某理论最优算法还优秀一点? 所以\(n,m\)说不定可以出到\(1000\)? 无所谓啦,反正是个得分题.Orz良心出题人,暴力有70分2333 思路分析 正解的 ...

  3. 2018.07.01洛谷P2617 Dynamic Rankings(带修主席树)

    P2617 Dynamic Rankings 题目描述 给定一个含有n个数的序列a[1],a[2],a[3]--a[n],程序必须回答这样的询问:对于给定的i,j,k,在a[i],a[i+1],a[i ...

  4. 2018.07.17 洛谷P1368 工艺(最小表示法)

    传送门 好的一道最小表示法的裸板,感觉跑起来贼快(写博客时评测速度洛谷第二),这里简单讲讲最小表示法的实现. 首先我们将数组复制一遍接到原数组队尾,然后维护左右指针分别表示两个即将进行比较的字符串的头 ...

  5. bzoj5248(洛谷4363)(2018九省联考)一双木棋

    题目:https://www.luogu.org/problemnew/show/P4363 一种考虑状态数的方法:有几个用了k个格子的列,就在第k个0的左边插入几个1: 这也是求不降序列的个数的方法 ...

  6. 2018.10.30 一题 洛谷4660/bzoj1168 [BalticOI 2008]手套——思路!问题转化与抽象!+单调栈

    题目:https://www.luogu.org/problemnew/show/P4660 https://www.lydsy.com/JudgeOnline/problem.php?id=1168 ...

  7. [洛谷P1842] 奶牛玩杂技

    题目类型:贪心+证明,经典题 传送门:>Here< 题意:有\(N\)头奶牛,每个奶牛有一个重量\(W[i]\),力量\(S[i]\).定义每个奶牛的压扁程度为排在它前面的所有奶牛的总量之 ...

  8. 洛谷P3375 [模板]KMP字符串匹配

    To 洛谷.3375 KMP字符串匹配 题目描述 如题,给出两个字符串s1和s2,其中s2为s1的子串,求出s2在s1中所有出现的位置. 为了减少骗分的情况,接下来还要输出子串的前缀数组next.如果 ...

  9. 洛谷 P2058 海港 解题报告

    P2058 海港 题目描述 小K是一个海港的海关工作人员,每天都有许多船只到达海港,船上通常有很多来自不同国家的乘客. 小K对这些到达海港的船只非常感兴趣,他按照时间记录下了到达海港的每一艘船只情况: ...

随机推荐

  1. HashMap之红黑树

    红黑树的设计,相比 jdk1.7 的 HashMap 而言,jdk1.8 最重要的就是引入了红黑树的设计,当冲突的链表长度超过 8 个的时候,链表结构就会转为红黑树结构. 01.故事的起因 “ JDK ...

  2. linux alloc_pages 接口

    为完整起见, 我们介绍另一个内存分配的接口, 尽管我们不会准备使用它直到 15 章. 现 在, 能够说 struct page 是一个描述一个内存页的内部内核结构. 如同我们将见到的, 在内核中有许多 ...

  3. MobaXterm 使用中间服务器

    经常需要连接服务器,但是有时候服务器需要经过一层中间服务器才可以连接,所以本文告诉大家如何使用MobaXterm 配置中间服务器,进行ssh连接 在本文的开始,本地转发服务器已经弄好,本文不会告诉大家 ...

  4. 由“Sysnative”引发的思考

    在64位的Windows系统中,有个非常神秘的文件夹“Sysnative”,你无法通过Explorer去访问它,甚至你都无法找到它,但它却扮演了一个非常重要的角色.下面我们就来聊聊它. 32位和64位 ...

  5. anaconda在本地安装软件conda install

    安装完anaconda后,想在mac下安装pytorch,但是在用官网提供的安装方法一直安装不上pytorch和torchvision,估计是被墙了 conda install pytorch tor ...

  6. python实现单词本功能

    #实现简单的单词本:# 可以添加单词和词义,当所添加的单词已经存在 让用户知道:# 查找单词,单词不存在时,让用户知道# 删除单词,当删除的单词不存在时,让用户知道# 以上功能无限制操作,直到用户输入 ...

  7. Java面向对象程序设计第14章3-8和第15章6

    Java面向对象程序设计第14章3-8和第15章6 3.完成下面方法中的代码,要求建立一个缓冲区,将字节输入流中的内容转为字符串. import java.io.*; public class tes ...

  8. Java图形打印 上下对称三角星

    记录记录 @Test public void name03() { int row = 9; for (int i=0,k=row,m=0;i< row;i++){ for(int l=m-i; ...

  9. DOCKER学习_002:Docker的容器管理

    一 Docker的基本信息 前面已经安装了Docker,现在看一下已安装Docker的安装环境以及其他信息 1.1 系统环境 [root@docker-server3 ~]# uname -r -.e ...

  10. 洛谷$P2050\ [NOI2012]$美食节 网络流

    正解:网络流 解题报告: 传送门$QwQ$ 昂开始看到$jio$得,哇长得好像上一题嗷$QwQ$ 然后仔细康康数据范围,发现,哇好像要几万个点,,,显然就$GG$了 但感$jio$思路方向好对的亚子? ...