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

为了使居民们都尽可能饮用到清澈的湖水,现在要在某些城市建造水利设施。水利设施有两种,分别为蓄水厂和输水站。蓄水厂的功能是利用水泵将湖泊中的水抽取到所在城市的蓄水池中。
因此,只有与湖泊毗邻的第1 行的城市可以建造蓄水厂。而输水站的功能则是通过输水管线利用高度落差,将湖水从高处向低处输送。故一座城市能建造输水站的前提,是存在比它海拔更高且拥有公共边的相邻城市,已经建有水利设施。由于第N 行的城市靠近沙漠,是该国的干旱区,所以要求其中的每座城市都建有水利设施。那么,这个要求能否满足呢?如果能,请计算最少建造几个蓄水厂;如果不能,求干旱区中不可能建有水利设施的城市数目。
输入输出格式
输入格式:
输入文件的每行中两个数之间用一个空格隔开。输入的第一行是两个正整数N 和M,表示矩形的规模。接下来N 行,每行M 个正整数,依次代表每座城市的海拔高度。
输出格式:
输出有两行。如果能满足要求,输出的第一行是整数1,第二行是一个整数,代表最少建造几个蓄水厂;如果不能满足要求,输出的第一行是整数0,第二行是一个整数,代表有几座干旱区中的城市不可能建有水利设施。
输入输出样例
【输入样例1】
2 5
9 1 5 4 3
8 7 6 1 2 【输入样例2】
3 6
8 4 5 6 4 4
7 3 4 3 3 3
3 2 2 1 1 2
【输出样例1】
1
1 【输出样例2】
1
3
说明
【样例1 说明】
只需要在海拔为9 的那座城市中建造蓄水厂,即可满足要求。
【样例2 说明】

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

--------------------------------------------------------------------------------------------
第一行覆盖最后一行
-------------------------------------------------------------------------------------------------
bfs一遍看看能否满足要求,dfs也可以,小心爆栈,复杂度O(n2)
对于每个店单独bfs或dfs求能覆盖那些点O(n3),可以发现每个店能覆盖的点是一段连续的区间
贪心求最小区间覆盖
O(n2+n3+nlogn)
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
using namespace std;
const int N=,INF=1e9;
inline int read(){
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
int n,m,h[N][N],ans0=,ans1=; struct data{
int x,y;
data(int a=,int b=):x(a),y(b){}
}q[N*N];
struct range{
int l,r;
}g[N];
bool cmp(range a,range b){
return a.l<b.l;
}
int vis[N][N],dx[]={-,,,},dy[]={,,,-};
void bfs(int x,int y){
if(vis[x][y]) return;vis[x][y]=;
int head=,tail=-;
q[++tail]=data(x,y);
while(head<=tail){
data now=q[head++];
for(int i=;i<;i++){
int nx=now.x+dx[i],ny=now.y+dy[i];
if(nx<||nx>n||ny<||ny>m||vis[nx][ny]) continue;
if(h[nx][ny]>=h[now.x][now.y]) continue;
vis[nx][ny]=;
q[++tail]=data(nx,ny);
}
}
}
void bfs2(int x,int y){
int head=,tail=-;
q[++tail]=data(x,y);vis[x][y]=;
while(head<=tail){
data now=q[head++];
if(now.x==n){
g[y].l=min(g[y].l,now.y);
g[y].r=max(g[y].r,now.y);
}
for(int i=;i<;i++){
int nx=now.x+dx[i],ny=now.y+dy[i];
if(nx<||nx>n||ny<||ny>m||vis[nx][ny]) continue;
if(h[nx][ny]>=h[now.x][now.y]) continue;
vis[nx][ny]=;
q[++tail]=data(nx,ny);
}
}
}
//void dfs(int x,int y,int now){
// vis[x][y]=1;
// if(x==n){
// g[now].l=min(g[now].l,y);
// g[now].r=max(g[now].r,y);
// }
// for (int i = 0;i < 4;i ++){
// int nx = x + dx[i];
// int ny = y + dy[i];
// if(nx<1||nx>n||ny<1||ny>m||vis[nx][ny]) continue;
// if(h[nx][ny]>=h[x][y]) continue;
// dfs(nx,ny,now);
// }
//}
int rg(){
sort(g+,g++m,cmp);
int now=,to=,cnt=;
for(int i=;i<=m;i++){
if(now+>=g[i].l) to=max(to,g[i].r);
else now=to,to=max(to,g[i].r),cnt++;
}
if(now!=m)cnt++;
return cnt;
}
int main(){
n=read();m=read();
for(int i=;i<=n;i++) for(int j=;j<=m;j++) h[i][j]=read(); for(int i=;i<=m;i++) bfs(,i);
for(int i=;i<=m;i++) if(vis[n][i]==) ans0++;
if(ans0>){
printf("0\n%d",ans0);return ;//
} for(int i=;i<=m;i++){//
memset(vis,,sizeof(vis));
g[i].l=m+;g[i].r=;
bfs2(,i);
//printf("g %d %d\n",g[i].l,g[i].r);
}
printf("1\n%d",rg());
}
NOIP2010引水入城[BFS DFS 贪心]的更多相关文章
- Luogu1514 NOIP2010 引水入城 BFS、贪心
传送门 NOIP的题目都难以写精简题意 考虑最上面一排的某一个点对最下面一排的影响是什么样的,不难发现必须要是一段连续区间才能够符合题意. 如果不是一段连续区间,意味着中间某一段没有被覆盖的部分比周围 ...
- noip2010 引水入城 bfs+贪心
如果能够实现,每个河边的城市对应的控制区域一定是一条线段. 所以直接bfs每个河边的城市,贪心线段的右端点 #include<cstdio> #include<cstring> ...
- luogu1514 [NOIp2010]引水入城 (bfs+记忆化搜索)
我们先bfs一下看看是否能到最底下的所有点 如果不能的话,直接把不能到的那几个数一数就行了 如果能的话: 可以发现(并不可以)某格能到达的最底下的格子一定是一个连续的区间 (因为如果不连续的话,我们先 ...
- 521. [NOIP2010] 引水入城 cogs
521. [NOIP2010] 引水入城 ★★★ 输入文件:flow.in 输出文件:flow.out 简单对比时间限制:1 s 内存限制:128 MB 在一个遥远的国度,一侧是风景秀 ...
- vijos p1777 引水入城(bfs+贪心)
引水入城 描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N行M列的矩形,其中每个格子都代表一座城市,每座城市都有一个海拔高度. 为了使 ...
- NOIP2010 引水入城
4引水入城 题目描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N 行M 列的矩形,如上图所示,其中每个格子都代表一座城市,每座城市都有一个 ...
- NOIP2010 引水入城 贪心+DFS
我们先把简单的不能搞死,具题意可证:每个蓄水长的管辖区域一定是连续的.证明:既然我们已经能了那么我们就可以说如果这个区间不是连续的那我们取出这个区间中间阻隔开的那一段,那么对于这一整个区间来说水源不可 ...
- [NOIP2010] 引水入城 贪心 + 记忆化搜索
---题面--- 题解: 本蒟蒻并没有想到bfs的做法,,,, 只会dfs了 首先我们需要知道一个性质. 我们设k[i].l 为在i点建立水库可以支援到的最左边的城市,k[i].r为最右边的. 那么点 ...
- NOIP2010_T4_引水入城 bfs+贪心
在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个 N 行 M 列的矩形,如上图所示,其中每个格子都代表一座城 市,每座城市都有一个海拔高度.为了使 ...
随机推荐
- 精通 CSS 选择器(二)
补充了一些之前遗漏掉的选择器以及一些在 Selectors Level 4 中新定义的选择器. 属性选择器不区分大小写 [attribute="value" i],在 Select ...
- 总结CSS3新特性(Transform篇)
概述: CSS3新添加的Transform可以改变元素在可视化区域的坐标(这种改变不会引起文档的重排,只有重排),以及形状,还有些3D形变.结合 Animation(这里以后会有个链接的) 能实现酷炫 ...
- 什么是REST?
云计算的时代越来越多的提到一个词REST,那么什么是REST?如果你还不清楚,可以看这个视频和系列教程: http://www.restapitutorial.com/lessons/whatisre ...
- OS X EI Capitan 系统 安装cocoapod
没有废话直接上步骤 (哪一步卡住了 多试几次 可能是网络不好的缘故) 1. 首先安装 home-brew 以下方法转自:http://www.cnblogs.com/lzrabbit/p/4 ...
- Udp通讯(零基础)
前面学习了Tcp通讯之后听老师同学们讲到Udp也可以通讯,实现还要跟简单,没有繁琐的连接,所以最近学习了一下,记录下来以便忘记,同时也发表出来与大家相互学习,下面是我自己写的一个聊天例子,实现了群聊私 ...
- 【IOS】从android角度来实现(理解)IOS的UITableView
以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/3403124.html 本人从在学校开始到现在上班(13年毕 ...
- This version of android studio is incompatible with the gradle version used.Try disabling the instant run解决办法
今天打开android studio又碰到一个奇怪的问题:This version of android studio is incompatible with the gradle version ...
- ios 颜色转图片
- (UIImage *)imageWithColor:(UIColor*) color{ CGRect rect=CGRectMake(0.0f, 0.0f, 1.0f, 1.0f); ...
- objective-c系列-NSMutableArray
******************************************** // 可变数组构造方法 // 下边两句的定义都是不可变的 // NSMutableArray *mar ...
- Java中的static的使用
Java中的static使用之静态变量 神话丿小王子的博客主页 1.Java 中被static修饰的成员称为静态成员或类成员.它属于整个类所有,而不是某个对象所有,即被类的所有对象所共享.且优先于对象 ...