题目大意

在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠。该国的行政区划十分特殊,刚好构成一个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 引水入城的更多相关文章

  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. js基础---数据类型转换

    js中数据类型: 简单数据类型: number:233,-34,0x23,023 string:"hello"或者'hello' boolean:true.false undefi ...

  2. HTML和CSS网页开发基础

    一 HTML文档结构 HTML文档结构:<html>.<head>.<title>.<body>构成HTML页面中最基本的元素. HTML常用标记:1. ...

  3. asp.net——统计输入的字符数目

    asp.net——统计输入的字符数目 题目: 在页面中有一个TextBox输入框,一个显示文字用的Label,一个提交按钮Button.在TextBox中输入一段英文字母,点击按钮提交后统计其中字母‘ ...

  4. 背包系列 hdu3449 有依赖背包

    这道题真正困扰了笔者3,4天,冥思苦想几日无果之后,只能去找大牛的解法.结合网上的大牛解法与自己的理解,笔者终于解决了这个坑了,在此小庆幸一下. 原题如下: Consumer Time Limit: ...

  5. 4星|《超级技术:改变未来社会和商业的技术趋势》:AI对人友好吗

    超级技术:改变未来社会和商业的技术趋势 多位专家或经济学人编辑关于未来的预测,梅琳达·盖茨写了其中一章.在同类书中属于水平比较高的,专家只写自己熟悉的领域,分析与预测有理有据而不仅仅是畅想性质. 以下 ...

  6. (转) Hibernate框架基础——操纵持久化对象的方法(Session中)

    http://blog.csdn.net/yerenyuan_pku/article/details/52761021 上一篇文章中我们学习了Hibernate中java对象的状态以及对象的状态之间如 ...

  7. js 不能用关键字 delete 做函数名

    把delete更改为mydelete正常.

  8. smtplib.SMTPDataError: (554, b'DT:SPM 126 smtp

    报错信息 smtplib.SMTPDataError: (554, b'DT:SPM 126 smtp7,DsmowAA3uguL7e1cyvkyFw--.22553S3 1559096715,ple ...

  9. Requirejs常用配置和应用

    requirejs.require方法冲突 如果加载了多个requirejs脚本,每个requirejs会判断是否浏览器已经实现了require和define方法.如果浏览器已经自带require和d ...

  10. 聊聊JS动画库:Velocity.js

    前言 又到了炎热的7月,很久没有更新技术文章了,原因是上月月底实习结束,从公司离职.然后最近在弄自己的项目和考驾照,为了下次公司的应聘做准备,送别了女朋友到外地,哩哩啦啦半个月把一切事情都办妥后,还是 ...