引水入城[NOI2010 ]
题目描述
在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠。该国的行政区划十分特殊,刚好构成一个N行M列的矩形,如上图所示,其中每个格子都代表一座城市,每座城市都有一个海拔高度。
为了使居民们都尽可能饮用到清澈的湖水,现在要在某些城市建造水利设施。水利设施有两种,分别为蓄水厂和输水站。蓄水厂的功能是利用水泵将湖泊中的水抽取到所在城市的蓄水池中。因此,只有与湖泊毗邻的第1行的城市可以建造蓄水厂。而输水站的功能则是通过输水管线利用高度落差,将湖水从高处向低处输送。故一座城市能建造输水站的前提,是存在比它海拔更高且拥有公共边的相邻城市,已经建有水利设施。
由于第N行的城市靠近沙漠,是该国的干旱区,所以要求其中的每座城市都建有水利设施。那么,这个要求能否满足呢?如果能,请计算最少建造几个蓄水厂;如果不能,求干旱区中不可能建有水利设施的城市数目。
输入
输入文件名为flow.in。输入文件的每行中两个数之间用一个空格隔开。
输入的第一行是两个正整数N和M,表示矩形的规模。
接下来N行,每行M个正整数,依次代表每座城市的海拔高度。
输出
输出文件名为flow.out。
输出有两行。如果能满足要求,输出的第一行是整数1,第二行是一个整数,代表最少建造几个蓄水厂;如果不能满足要求,输出的第一行是整数0,第二行是一个整数,代表有几座干旱区中的城市不可能建有水利设施。
样例输入
- 输入输出样例1】
- flow.in
- 2 5
- 9 1 5 4 3
- 8 7 6 1 2
- flow.out
- 1
- 1
- 【样例1说明】
- 只需要在海拔为9的那座城市中建造蓄水厂,即可满足要求。
样例输出
- 【输入输出样例2】
- flow.in
- 3 6
- 8 4 5 6 4 4
- 7 3 4 3 3 3
- 3 2 2 1 1 2
- flow.out
- 1
- 3
提示
【样例2说明】
湖泊
8 4 5 6 4 4
7 3 4 3 3 3
3 2 2 1 1 2
沙漠
上图中,在3个粗线框出的城市中建造蓄水厂,可以满足要求。以这3个蓄水厂为源头在干旱区中建造的输水站分别用3种颜色标出。当然,建造方法可能不唯一。
【数据范围】
- 一堆大搜索= =深搜宽搜暴搜各种搜。成绩没有前天那么惨,但是也不是特别好。后半段调第四题莫名卡死的深搜花了很长时间,到后来觉得有点懊丧完全是浪费时间。然后回来看其他题,打了几个不知所云的优化,也没有本质上改变效率。前半段还是非常不错的,前两题也觉得做得差不多。考试次数虽然多,但还没有变得麻木,依然每次都是需要勇气的冒险。
- 一道看起来很可做但是被我想麻烦了的题,正解是dfs/bfs+贪心。因为没有想到它覆盖的区间一定是连续的,考试的时候打了两个dfs,实现起来其实很困难,用了三个vector来正搜反搜。后来回来优化,觉得队列或许要比动态数组快一些,就把其中一个改成了队列,亲测队列比vector多过了一个点(总共只过了一个点QAQ)。弄明白了只要能完全覆盖就一定是线段,这就是一个显而易见的贪心了,从左往右扫覆盖区间选最优即可。不知道为什么没有标记的dfs会超时,有标记的dfs搜不出正确答案,逼得我一样的dfs有标记无标记做了两次,第一次判断有无解,有解则用第二次处理覆盖区间;不过居然很快?!考试的时候往往想不到贪心,即使用了也意识不到自己在打贪心,看来这种思想还要更强化一下。一道题能用贪心来做,往往可以节省很多时间和代码量,不过贪心的可行性是需要谨慎检验的。
- #include<iostream>
- #include<cstdio>
- #include<cstring>
- #include<algorithm>
- using namespace std;
- const int sj=;
- int n,m,hb[sj][sj],ans,mi,ma,e,ge;
- bool kd[sj],jg[sj][sj];
- inline int r()
- {
- int jg=,jk=;
- jk=getchar()-'';
- if(jk>=&&jk<=) jg+=jk;
- jk=getchar()-'';
- while(jk>=&&jk<=)
- {
- jg*=;
- jg+=jk;
- jk=getchar()-'';
- }
- return jg;
- }
- void bj(int &x,int y)
- {
- x=x<y?x:y;
- }
- void db(int &x,int y)
- {
- x=x>y?x:y;
- }
- struct T
- {
- int le,ri;
- }t[sj];
- int comp(const T&a,const T&b)
- {
- if(a.le==b.le) return a.ri>b.ri;
- return a.le<b.le;
- }
- void dfs1(int y,int x)
- {
- if(y<=||y>n||x<=||x>m) return;
- if(y==n)
- {
- bj(mi,x);
- db(ma,x);
- }
- if(hb[y][x]>hb[y+][x]) dfs1(y+,x);
- if(hb[y][x]>hb[y-][x]) dfs1(y-,x);
- if(hb[y][x]>hb[y][x+]) dfs1(y,x+);
- if(hb[y][x]>hb[y][x-]) dfs1(y,x-);
- }
- void dfs2(int y,int x)
- {
- if(y<=||y>n||x<=||x>m) return;
- jg[y][x]=;
- if(y==n)
- kd[x]=;
- if(hb[y][x]>hb[y+][x]&&!jg[y+][x]) dfs2(y+,x);
- if(hb[y][x]>hb[y-][x]&&!jg[y-][x]) dfs2(y-,x);
- if(hb[y][x]>hb[y][x+]&&!jg[y][x+]) dfs2(y,x+);
- if(hb[y][x]>hb[y][x-]&&!jg[y][x-]) dfs2(y,x-);
- }
- int main()
- {
- n=r();
- m=r();
- memset(hb,0x7f,sizeof(hb));
- for(int i=;i<=n;i++)
- for(int j=;j<=m;j++)
- hb[i][j]=r();
- hb[][]=;
- hb[][m+]=;
- for(int i=;i<=m;i++)
- if(hb[][i]>=hb[][i+]&&hb[][i]>=hb[][i-])
- dfs2(,i);
- for(int i=;i<=m;i++)
- if(!kd[i])
- ge++;
- if(ge!=)
- {
- printf("0\n%d",ge);
- return ;
- }
- for(int i=;i<=m;i++)
- if(hb[][i]>=hb[][i+]&&hb[][i]>=hb[][i-])
- {
- mi=0x7fffffff;
- ma=;
- dfs1(,i);
- if(ma!=)
- {
- e++;
- t[e].le=mi;
- t[e].ri=ma;
- }
- }
- sort(t+,t+e+,comp);
- int yd,temp=;
- yd=t[].ri;
- ans=;
- for(int i=;i<=e;i++)
- {
- if(t[i].le<=yd+)
- db(temp,t[i].ri);
- if(t[i].le>yd+)
- {
- yd=temp;
- ans++;
- if(t[i].le<=yd+)
- db(temp,t[i].ri);
- }
- }
- if(yd<m)
- ans++;
- printf("1\n%d",ans);
- return ;
- }
引水入城[NOI2010 ]的更多相关文章
- NOIP2010 引水入城
4引水入城 题目描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N 行M 列的矩形,如上图所示,其中每个格子都代表一座城市,每座城市都有一个 ...
- Codevs 1066 引水入城 2010年NOIP全国联赛提高组
1066 引水入城 2010年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description 在一个遥远的国度 ...
- CODEVS 1066/洛谷 P1514引水入城
1066 引水入城 2010年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 在一个遥远的国 ...
- Luogu 1514 引水入城 (搜索,动态规划)
Luogu 1514 引水入城 (搜索,动态规划) Description 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N行M列的矩形,如上图 ...
- CCF CSP 201703-5 引水入城(50分)
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201703-5 引水入城 问题描述 MF城建立在一片高原上.由于城市唯一的水源是位于河谷地带的 ...
- 洛谷P1514 引水入城
洛谷P1514 引水入城 原题链接 一道好题...细节真多 第一次提交90分,然后就GG了,不知从何改起 其实比较简单吧... 首先,一个点的水流向最后一排,一定可以形成一个区间. 不行的话肯定GG ...
- 洛谷 P1514 引水入城 解题报告
P1514 引水入城 题目描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个 NN 行 \times M×M 列的矩形,如上图所示,其中每个格 ...
- 洛谷P1514 引水入城 [搜索,区间DP]
题目传送门 引水入城 题目描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个 N 行×M 列的矩形,如上图所示,其中每个格子都代表一座城市,每 ...
- vijos p1777 引水入城(bfs+贪心)
引水入城 描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N行M列的矩形,其中每个格子都代表一座城市,每座城市都有一个海拔高度. 为了使 ...
随机推荐
- HTML基础了解
对HTML最基本的认识和编写:"我的第一个网页" HTML是什么: 它的全称是Hyper Text Markup Language超文本标记语言,页面中包括有视频.图片.链接等其 ...
- Hibernate的使用
1 创建一个Java项目,在项目中新建一个lib,将需要的Hibernate包和MySQL包导入,并Build Path 2 在src下添加Hibernate.cfg.xml在此文件中对Hiberna ...
- 学习php语法--数据库扩展(总结篇)
前 言 php php中的数据库扩展mysql语法--本篇学习都是通过使用数字天堂的HBuider开发环境,连接mysql数据.介绍php连接mysql数据库的代码与函数. 本篇学习主要有两 ...
- Index Scans 索引扫描
官方文档链接地址 http://docs.oracle.com/cd/E11882_01/server.112/e40540/indexiot.htm#CNCPT1170 Index Scans 在索 ...
- 两种代理模式(JDK和Cglib)实例
CGlib代理模式: package CGLIB; import java.lang.reflect.Method; import JDK.Test; import net.sf.cglib.prox ...
- 既然函数也是对象,那么为什么this不指向普通函数?
function a(){ var b=1; function exp(){ alert(this.b); } exp(); } var b=2; a(); 既然函数是对象,且exp是在a中运行的,那 ...
- MaintainableCSS 《可维护性 CSS》 --- ID 篇
ID 从语法上讲,当只有一个实例时,我们应该使用一个ID.当有多个时,我们应该使用一个 class. 但是,ID 作用的优先级高于 class ,在我们想覆盖一个样式的时候,这就会导致问题. 为了演示 ...
- centos 7 安装MySQL 5.6
本文根据mysql的官方文档操作:https://dev.mysql.com/doc/mysql-yum-repo-quick-guide/en/ 由于Centos7 默认数据库是mariabd(网上 ...
- 安卓巴士android源码、博文精选1
每周精选 第 53 期 精品源码 Android开源项目--CookMan 厨客APP 简介CookMan,厨客,是一款查询.搜索.分类.收藏菜谱功能的APP.|52数据来源Mob A ...
- C#获取数据库连接字符
有两种用法:1)using System.Configuraiton; string ConStr=ConfigurationManager.ConnectionStrings["ConSt ...