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

为了使居民们都尽可能饮用到清澈的湖水,现在要在某些城市建造水利设施。水利设施有两种,分别为蓄水厂和输水站。蓄水厂的功能是利用水泵将湖泊中的水抽取到所在城市的蓄水池中。
因此,只有与湖泊毗邻的第11 行的城市可以建造蓄水厂。而输水站的功能则是通过输水管线利用高度落差,将湖水从高处向低处输送。故一座城市能建造输水站的前提,是存在比它海拔更高且拥有公共边的相邻城市,已经建有水利设施。由于第NN 行的城市靠近沙漠,是该国的干旱区,所以要求其中的每座城市都建有水利设施。那么,这个要求能否满足呢?如果能,请计算最少建造几个蓄水厂;如果不能,求干旱区中不可能建有水利设施的城市数目。
第二问思路

注意
说沙城构成连续的区间是在有解的情况下才成立的。
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <functional>
#include <queue>
#include <cassert>
using namespace std; #define Pair pair<int, int>
#define UpdateMin(x, y) x = min(x, y)
#define UpdateMax(x, y) x = max(x, y) const int MAX_NODE = 510, INF = 0x3f3f3f3f;
const int Next[4][2] = { {0, 1}, {1, 0}, {0, -1}, {-1, 0} };
int A[MAX_NODE][MAX_NODE];
bool Vis[MAX_NODE][MAX_NODE];
bool Connect[MAX_NODE];
int TotRow, TotCol; struct RangeCover
{
private:
Pair ranges[MAX_NODE];
int TotRange, L, R; public:
void Insert(Pair range)
{
ranges[++TotRange] = range;
} int GetCnt()
{
sort(ranges + 1, ranges + TotRange + 1);
ranges[++TotRange] = Pair(INF, INF);
int lBegin = 1, p = 1, ans = 0;
while (lBegin <= TotCol)
{
while (ranges[p + 1].first <= lBegin)
p++;
assert(ranges[p].first <= lBegin && ranges[p].second >= lBegin);
ans++;
lBegin = ranges[p].second + 1;
}
return ans;
}
}g; Pair Bfs(int startCol)
{
for (int i = 1; i <= TotRow; i++)
for (int j = 1; j <= TotCol; j++)
Vis[i][j] = false;
Pair ans(INF, -INF);
static queue<Pair> q;
while (!q.empty())
q.pop();
q.push(Pair(1, startCol));
while (!q.empty())
{
Pair cur = q.front();
q.pop();
if (Vis[cur.first][cur.second])
continue;
Vis[cur.first][cur.second] = true;
if (cur.first == TotRow)
{
Connect[cur.second] = true;
UpdateMin(ans.first, cur.second);
UpdateMax(ans.second, cur.second);
}
for (int i = 0; i < 4; i++)
{
int nextRow = cur.first + Next[i][0], nextCol = cur.second + Next[i][1];
if (A[nextRow][nextCol] < A[cur.first][cur.second])
q.push(Pair(nextRow, nextCol));
}
}
return ans;
} void Build()
{
for (int i = 1; i <= TotCol; i++)
{
if ((i == 1 || A[1][i - 1] <= A[1][i])
&& (i == TotCol || A[1][i + 1] <= A[1][i]))
{
Pair lr = Bfs(i);
if (lr.first < INF && lr.second > -INF)
g.Insert(lr);
}
}
} int Check()
{
int ans = 0;
for (int i = 1; i <= TotCol; i++)
ans += (!Connect[i]);
return ans;
} int main()
{
memset(A, INF, sizeof(A));
scanf("%d%d", &TotRow, &TotCol);
for (int i = 1; i <= TotRow; i++)
for (int j = 1; j <= TotCol; j++)
scanf("%d", &A[i][j]);
Build();
int failCnt = Check();
if (failCnt > 0)
{
printf("0\n%d\n", failCnt);
return 0;
}
printf("1\n%d\n", g.GetCnt());
return 0;
}
luogu1514 引水入城的更多相关文章
- 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列的矩形,其中每个格子都代表一座城市,每座城市都有一个海拔高度. 为了使 ...
随机推荐
- Android RecyclerView利用Glide加载大量图片into(Target)导致OOM异常
学过android的人应该都知道Glide是一个无比强大的图片加载库,它内部已经提供了很好的缓存机制供我们选择,我们只需一个参数调用即可(DiskCacheStrategy()),而不必像Univer ...
- Win32编程笔记
我都决定了目前不再接触这些个浪费精力的API了,结果为了DirectX编程我特么又回来了.....微软你的东西真是坑人 以前用这玩意的时候需要什么就查,查完就忘了,这次记一记,以后再用也不至于忘的太离 ...
- jboss启动问题
今天一大早客户找我,说他们那边的jboss启动成功了,但是却访问不了. 本以为不是什么事,估计又是客户不会搞,把哪里搞挂了,直接远程把客户的jboss的log.data.tmp等文件给清理了,然后重启 ...
- CAD当前选择实体发生变化调用事件(com接口)
主要用到函数说明: _DMxDrawXEvents::SelectModified 当前选择实体发生变化,会调用该事件,详细说明如下: 参数 说明 IDispatch* pAryId 当前被选择的实体 ...
- Sersync+Rsync实现数据文件实时同步
rsync+inotify-tools与rsync+sersync架构的区别1,rsync+inotify-tools只能记录下被监听的目录发生的变化(增删改)并没有把具体变化的文件或目录记录下来在同 ...
- js 简单小知识
1. javascript的typeof返回哪些数据类型: string, boolean, number, undefined, function, object 2. split() join() ...
- 16.1 foreach 循环中捕获变量的变化
在 foreach 循环内的匿名函数(通常为Lambda表达式)中捕获循环 变量时要格外小心.代码清单16-1就展示了这样一个简单的示例,它看上去似乎会输出 x . y . z . string[] ...
- 洛谷——P2169 正则表达式
P2169 正则表达式 题目背景 小Z童鞋一日意外的看到小X写了一个正则表达式的高级程序,这个正则表达式程序仅仅由字符“0”,“1”,“.”和“*”构成,但是他能够匹配出所有在OJ上都AC的程序的核心 ...
- Miller Rabbin素数测试
步骤 ①先写快速幂取模函数 ②MR算法开始 (1)传入两个参数一个是底数一个是n也就是幂数,如果n是一个合数那么可以判定,这个数一定不是素数 (2)然后开始寻找一个奇数的n去计算,如果最后满足a^d% ...
- 38.histogram的基础用法
主要知识点 histogram的理解及用法 histogram:他的作用是把一些连续的数据划分为一定的区间范围,使用连续的数据离散化,然后这这样离散化的数据就可以做聚合分析操作,操作过程类似于 ...