跟 zzy, hwx 等人纠结是否回去上蛋疼的董老板的课。

题目描述



如图所示。你有一个 N×MN\times MN×M 的矩阵,水可以从一格流到与它相邻的格子,需要满足起点的海拔严格高于终点海拔。定义两个格子相邻,当且仅当它们合法存在,且它们的横坐标和纵坐标中有且仅有一个相同,另一个数值之差严格为 111。请你告诉我,至少需要在第一行的多少格上放水,才能使最后一行的所有格子都有水。

Solution

这算是我想到的一个贪心吧。从左往右处理最后一行的每个点,找到选中后水能流到这个点的、第一行的最右边的点,并打通这个点。标记所有被该点浇灌的格子。

证明: 当处理到第 yyy 格的时候,前 y−1y-1y−1 格早已被处理完毕。所以如果在第一行存在两个点,它们都能浇到 yyy,选右边的点显然更有意义,因为它貌似有潜力浇灌更多的点。

时间复杂度 O(N3)O(N^3)O(N3)。

#include<cstdio>
#include<cstdlib>
#include<cstring> const int MAXN=510; int n,m;
int fx[6]={0,0,1,-1};
int fy[6]={1,-1,0,0};
bool vis[MAXN][MAXN];
struct node{
int x,y;
}q[MAXN*MAXN*10];
int st,ed;
int a[MAXN][MAXN];
int tf[MAXN]; void SPFA(int stx,int sty,int type){
st=1;ed=2;
q[st].x=stx;q[st].y=sty;
memset(vis,0,sizeof(vis));vis[stx][sty]=1;
while(st!=ed){
node x=q[st];
for(int i=0;i<4;++i){
int nx=x.x+fx[i],ny=x.y+fy[i];
if(nx<1||nx>n||ny<1||ny>m) continue;
if(vis[nx][ny]||(type?(a[nx][ny]<=a[x.x][x.y]):(a[nx][ny]>=a[x.x][x.y]))) continue;
vis[nx][ny]=1;
q[ed].x=nx;q[ed++].y=ny;
}
++st;
}
}
int work(int ST){
SPFA(n,ST,1);
ST=0;
for(int i=m;i>=1;--i)
if(vis[1][i]){
ST=i;
break;
}
if(!ST) return 0;
SPFA(1,ST,0);
for(int i=1;i<=m;++i)
if(vis[n][i])
tf[i]=1;
return 1;
}
int main(){
scanf("%d%d",&n,&m);
for(int i=1;i<=n;++i)
for(int j=1;j<=m;++j)
scanf("%d",&a[i][j]);
memset(tf,0,sizeof(tf));
int cnt=0,ans=0;
for(int i=1;i<=m;++i){
if(tf[i]) continue;
int r=work(i);
if(!r)
++cnt;
else
++ans;
}
if(cnt)
printf("0\n%d",cnt);
else
printf("1\n%d",ans);
}

[NOIp2010] luogu P1514 引水入城的更多相关文章

  1. [luogu]P1514 引水入城[搜索][记忆化][DP]

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

  2. 【luogu P1514 引水入城】 题解

    题目链接:https://www.luogu.org/problemnew/show/P1514 // luogu-judger-enable-o2 #include <iostream> ...

  3. Luogu P1514 引水入城

    我承认我有点懒(洛谷已经发过题解了,但我发誓要坚持写博客) 这道题坑了我3天…… 首先一看就与染色问题类似,果断BFS(写DFS炸了) 先将最上面(靠近水)的一行全部扔进队列里,做一遍BFS 再对最下 ...

  4. Luogu P1514引水入城【搜索】 By cellur925

    题目传送门 这道题开始看好像并没有什么思路,和搜索好像也并没有什么关系.但是我们手玩下样例就会发现,思路其实就三句话:(写这道题的时候在代码里写的) //我们想知道从第1行的每列往下到干旱区的范围 / ...

  5. LUOGU P1514 引水入城 (bfs)

    传送门 解题思路 拉了很长的战线,换了好几种写法终于过了..首先每个蓄水场一定是对沙漠造成连续一段的贡献,所以可以$bfs$出每种状态,然后做一次最小区间覆盖,但这样的复杂度有点高.就每次只搜那些比左 ...

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

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

  7. 洛谷P1514 引水入城

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

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

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

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

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

随机推荐

  1. nodejs实现聊天机器人

    技术栈 服务端: koa.koa-route.koa-websocket.request. 客户端: html.css.js.websocket. 远程聊天API: http://api.qingyu ...

  2. 【带着canvas去流浪(14)】Three.js中凹浮雕模型的生成方式

    目录 一. 方案1:ThreeBSP.js或ThreeCSG.js扩展库 二. 方案2:平面镂空模型拉伸 三. 方案3:Cinema 4D建模后输出模型文件 示例代码托管在:http://www.gi ...

  3. Hadoop 之 HDFS基本概念

    1.HDFS的基本概念 答:块(Block).NameNode.DataNode.HDFS的文件被分成块进行存储,默认块的大小为64M,所以说块是文件存储和处理的逻辑单元.NameNode是管理节点, ...

  4. Python3.7.4入门-0/1To Begin/数据类型与结构

    0 To Begin //:向下取整除法 **:乘方 在交互模式下,上一次打印出来的表达式被赋值给变量 _ 如果不希望前置了 \ 的字符转义成特殊字符,可以使用 原始字符串 方式,在引号前添加 r 即 ...

  5. html常见的块元素与内联(行内)元素用法说明(一)

    html平时常见的块元素有:div, p, h1, h2, h3等,内联元素有:span, a, img等. 块元素的属性:无论内容是什么,都会独占一整行.主要用于页面布局. 内联元素的属性:只占自身 ...

  6. freemarker常用属性

    1.th:action 定义后台控制器的路径,类似<form>标签的action属性. 示例如下. <form id="login" th:action=&quo ...

  7. ajax 请求前后处理

    1. 介绍 通过 jQuery 提供的 ajaxSetup 方法,我们可以拦截页面上所有的 Ajax 请求响应(包括 $.ajax.$.post.$.get).这样我们可以对这些 Ajax 请求响应做 ...

  8. selenium实现百度图片爬取

    因为是百度图片是瀑布流ajax异步上传的数据,所以这里用到抓包工具来抓取链接(fiddler) 好了直接上代码, from selenium import webdriver from seleniu ...

  9. Stanford公开课《编译原理》学习笔记(2)递归下降法

    目录 一. Parse阶段 CFG Recursive Descent(递归下降遍历) 二. 递归下降遍历 2.1 预备知识 2.2 多行语句的处理思路 2.3 简易的文法定义 2.4 文法产生式的代 ...

  10. Java中的static(1)【持续更新】——关于Eclipse的No enclosing instance of type ... 错误的理解和改正

    No enclosing instance of type SomeClass is accessible. Must qualify the allocation with an enclosing ...