题目描述

在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠。该国的行政区划十分特殊,刚好构成一个N行M列的矩形,如上图所示,其中每个格子都代表一座城市,每座城市都有一个海拔高度。

为了使居民们都尽可能饮用到清澈的湖水,现在要在某些城市建造水利设施。水利设施有两种,分别为蓄水厂和输水站。蓄水厂的功能是利用水泵将湖泊中的水抽取到所在城市的蓄水池中。因此,只有与湖泊毗邻的第1行的城市可以建造蓄水厂。而输水站的功能则是通过输水管线利用高度落差,将湖水从高处向低处输送。故一座城市能建造输水站的前提,是存在比它海拔更高且拥有公共边的相邻城市,已经建有水利设施。

由于第N行的城市靠近沙漠,是该国的干旱区,所以要求其中的每座城市都建有水利设施。那么,这个要求能否满足呢?如果能,请计算最少建造几个蓄水厂;如果不能,求干旱区中不可能建有水利设施的城市数目。

输入

输入文件名为flow.in。输入文件的每行中两个数之间用一个空格隔开。

输入的第一行是两个正整数N和M,表示矩形的规模。

接下来N行,每行M个正整数,依次代表每座城市的海拔高度。

输出

输出文件名为flow.out。

输出有两行。如果能满足要求,输出的第一行是整数1,第二行是一个整数,代表最少建造几个蓄水厂;如果不能满足要求,输出的第一行是整数0,第二行是一个整数,代表有几座干旱区中的城市不可能建有水利设施。

样例输入

  1. 输入输出样例1
  2. flow.in
  3. 2 5
  4. 9 1 5 4 3
  5. 8 7 6 1 2
  6. flow.out
  7. 1
  8. 1
  9. 【样例1说明】
  10. 只需要在海拔为9的那座城市中建造蓄水厂,即可满足要求。

样例输出

  1. 【输入输出样例2
  2. flow.in
  3. 3 6
  4. 8 4 5 6 4 4
  5. 7 3 4 3 3 3
  6. 3 2 2 1 1 2
  7. flow.out
  8. 1
  9. 3

提示

【样例2说明】

湖泊

8 4 5 6 4 4

7 3 4 3 3 3

3 2 2 1 1 2

沙漠

上图中,在3个粗线框出的城市中建造蓄水厂,可以满足要求。以这3个蓄水厂为源头在干旱区中建造的输水站分别用3种颜色标出。当然,建造方法可能不唯一。

【数据范围】

  1. 一堆大搜索= =深搜宽搜暴搜各种搜。成绩没有前天那么惨,但是也不是特别好。后半段调第四题莫名卡死的深搜花了很长时间,到后来觉得有点懊丧完全是浪费时间。然后回来看其他题,打了几个不知所云的优化,也没有本质上改变效率。前半段还是非常不错的,前两题也觉得做得差不多。考试次数虽然多,但还没有变得麻木,依然每次都是需要勇气的冒险。
  2.  
  3. 一道看起来很可做但是被我想麻烦了的题,正解是dfs/bfs+贪心。因为没有想到它覆盖的区间一定是连续的,考试的时候打了两个dfs,实现起来其实很困难,用了三个vector来正搜反搜。后来回来优化,觉得队列或许要比动态数组快一些,就把其中一个改成了队列,亲测队列比vector多过了一个点(总共只过了一个点QAQ)。弄明白了只要能完全覆盖就一定是线段,这就是一个显而易见的贪心了,从左往右扫覆盖区间选最优即可。不知道为什么没有标记的dfs会超时,有标记的dfs搜不出正确答案,逼得我一样的dfs有标记无标记做了两次,第一次判断有无解,有解则用第二次处理覆盖区间;不过居然很快?!考试的时候往往想不到贪心,即使用了也意识不到自己在打贪心,看来这种思想还要更强化一下。一道题能用贪心来做,往往可以节省很多时间和代码量,不过贪心的可行性是需要谨慎检验的。
  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<algorithm>
  5. using namespace std;
  6. const int sj=;
  7. int n,m,hb[sj][sj],ans,mi,ma,e,ge;
  8. bool kd[sj],jg[sj][sj];
  9. inline int r()
  10. {
  11. int jg=,jk=;
  12. jk=getchar()-'';
  13. if(jk>=&&jk<=) jg+=jk;
  14. jk=getchar()-'';
  15. while(jk>=&&jk<=)
  16. {
  17. jg*=;
  18. jg+=jk;
  19. jk=getchar()-'';
  20. }
  21. return jg;
  22. }
  23. void bj(int &x,int y)
  24. {
  25. x=x<y?x:y;
  26. }
  27. void db(int &x,int y)
  28. {
  29. x=x>y?x:y;
  30. }
  31. struct T
  32. {
  33. int le,ri;
  34. }t[sj];
  35. int comp(const T&a,const T&b)
  36. {
  37. if(a.le==b.le) return a.ri>b.ri;
  38. return a.le<b.le;
  39. }
  40. void dfs1(int y,int x)
  41. {
  42. if(y<=||y>n||x<=||x>m) return;
  43. if(y==n)
  44. {
  45. bj(mi,x);
  46. db(ma,x);
  47. }
  48. if(hb[y][x]>hb[y+][x]) dfs1(y+,x);
  49. if(hb[y][x]>hb[y-][x]) dfs1(y-,x);
  50. if(hb[y][x]>hb[y][x+]) dfs1(y,x+);
  51. if(hb[y][x]>hb[y][x-]) dfs1(y,x-);
  52. }
  53. void dfs2(int y,int x)
  54. {
  55. if(y<=||y>n||x<=||x>m) return;
  56. jg[y][x]=;
  57. if(y==n)
  58. kd[x]=;
  59. if(hb[y][x]>hb[y+][x]&&!jg[y+][x]) dfs2(y+,x);
  60. if(hb[y][x]>hb[y-][x]&&!jg[y-][x]) dfs2(y-,x);
  61. if(hb[y][x]>hb[y][x+]&&!jg[y][x+]) dfs2(y,x+);
  62. if(hb[y][x]>hb[y][x-]&&!jg[y][x-]) dfs2(y,x-);
  63. }
  64. int main()
  65. {
  66. n=r();
  67. m=r();
  68. memset(hb,0x7f,sizeof(hb));
  69. for(int i=;i<=n;i++)
  70. for(int j=;j<=m;j++)
  71. hb[i][j]=r();
  72. hb[][]=;
  73. hb[][m+]=;
  74. for(int i=;i<=m;i++)
  75. if(hb[][i]>=hb[][i+]&&hb[][i]>=hb[][i-])
  76. dfs2(,i);
  77. for(int i=;i<=m;i++)
  78. if(!kd[i])
  79. ge++;
  80. if(ge!=)
  81. {
  82. printf("0\n%d",ge);
  83. return ;
  84. }
  85. for(int i=;i<=m;i++)
  86. if(hb[][i]>=hb[][i+]&&hb[][i]>=hb[][i-])
  87. {
  88. mi=0x7fffffff;
  89. ma=;
  90. dfs1(,i);
  91. if(ma!=)
  92. {
  93. e++;
  94. t[e].le=mi;
  95. t[e].ri=ma;
  96. }
  97. }
  98.  
  99. sort(t+,t+e+,comp);
  100. int yd,temp=;
  101. yd=t[].ri;
  102. ans=;
  103. for(int i=;i<=e;i++)
  104. {
  105. if(t[i].le<=yd+)
  106. db(temp,t[i].ri);
  107. if(t[i].le>yd+)
  108. {
  109. yd=temp;
  110. ans++;
  111. if(t[i].le<=yd+)
  112. db(temp,t[i].ri);
  113. }
  114. }
  115. if(yd<m)
  116. ans++;
  117. printf("1\n%d",ans);
  118. return ;
  119. }
  1.  

引水入城[NOI2010 ]的更多相关文章

  1. NOIP2010 引水入城

    4引水入城 题目描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N 行M 列的矩形,如上图所示,其中每个格子都代表一座城市,每座城市都有一个 ...

  2. Codevs 1066 引水入城 2010年NOIP全国联赛提高组

    1066 引水入城 2010年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description 在一个遥远的国度 ...

  3. CODEVS 1066/洛谷 P1514引水入城

    1066 引水入城 2010年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond   题目描述 Description 在一个遥远的国 ...

  4. Luogu 1514 引水入城 (搜索,动态规划)

    Luogu 1514 引水入城 (搜索,动态规划) Description 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N行M列的矩形,如上图 ...

  5. CCF CSP 201703-5 引水入城(50分)

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201703-5 引水入城 问题描述 MF城建立在一片高原上.由于城市唯一的水源是位于河谷地带的 ...

  6. 洛谷P1514 引水入城

    洛谷P1514 引水入城 原题链接 一道好题...细节真多 第一次提交90分,然后就GG了,不知从何改起 其实比较简单吧... 首先,一个点的水流向最后一排,一定可以形成一个区间. 不行的话肯定GG ...

  7. 洛谷 P1514 引水入城 解题报告

    P1514 引水入城 题目描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个 NN 行 \times M×M 列的矩形,如上图所示,其中每个格 ...

  8. 洛谷P1514 引水入城 [搜索,区间DP]

    题目传送门 引水入城 题目描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个 N 行×M 列的矩形,如上图所示,其中每个格子都代表一座城市,每 ...

  9. vijos p1777 引水入城(bfs+贪心)

    引水入城   描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N行M列的矩形,其中每个格子都代表一座城市,每座城市都有一个海拔高度. 为了使 ...

随机推荐

  1. oracle备份、还原

    ----第一步:设置空表导出 ----由于Oracle 11G在用EXPORT导出时,空表不能导出.解决方法如下:(11G中有个新特性,当表无数据时,不分配segment,以节省空间) select ...

  2. ECSHOP购物车页面显示商品简单描述

    1.这里说的商品简单描述,不是商品的详细信息,而是后台编辑商品时在“其他信息”标签栏填写的那个“商品简单描述”,即goods_brief字段 2.修改lib_order.php文件的get_cart_ ...

  3. Angular4 后台管理系统搭建(2) - flexgrid 单元格模板 wjFlexGridCellTemplate 的坑

    这几天中了很多坑,尤其是两个大坑.先是运行环境的坑,在是flexgrid单元格内部模板的坑.这里记录下. 一开始我遇见一些很奇怪的问题,按网上的说法,别人这么写代码都正常,就在我机器上不正常.按以前的 ...

  4. Kafka 源代码分析之log框架介绍

    这里主要介绍log管理,读写相关的类的调用关系的介绍. 在围绕log的实际处理上.有很多层的封装和调用.这里主要介绍一下调用结构和顺序. 首先从LogManager开始. 调用关系简单如下:LogMa ...

  5. JAVA基础——异常详解

    JAVA异常与异常处理详解 一.异常简介 什么是异常? 异常就是有异于常态,和正常情况不一样,有错误出错.在java中,阻止当前方法或作用域的情况,称之为异常. java中异常的体系是怎么样的呢? 1 ...

  6. Linux系统目录结构介绍

    参考博客: http://www.cnblogs.com/chensiqiqi/p/6243549.html 感谢原博主为我学习Linux指明方向!! linux目录:一切从“根”开始,“/”是所有目 ...

  7. 如何判断浏览器为ie10以上

    如果针对ie10 以上单独写css样式的话,ie10以上已经不提供 <!--[if ...]><![endif]--> 这种方法去操作了,所以可以用css媒体查询的方法@med ...

  8. CentOS 下搭建FTP服务器

    vsftpd是Linux下比较著名的FTP服务器,搭建FTP服务器当然首选这个.本文介绍了在CentOS 6 4下安装vsftpd.配置虚拟用户登录FTP的过程.正 vsftpd是Linux下比较著名 ...

  9. poj 1948 Triangular Pastures 小结

    Description Like everyone, cows enjoy variety. Their current fancy is new shapes for pastures. The o ...

  10. 官方Tomcat镜像Dockerfile分析及镜像使用

    官方Tomcat镜像 地址:https://hub.docker.com/_/tomcat/ 镜像的Full Description中,我们可以得到许多信息,这里简单介绍下: Supported ta ...