题目大意

在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠。该国的行政区划十分特殊,刚好构成一个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. 鼠标单击到 img行的时候图片隐藏方案

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. CSS——滑动门

    在背景图片中可以对图片进行圆角设置,但是这样是写死的.如下图: 情况分析:如果我们li标签中的文字变少了或者变多了,我们就需要重新定义背景图片.所以我们使用滑动门技术.它将图片特殊地方进行分割.宽度利 ...

  3. 【译】x86程序员手册08 -2.6中断和异常

    2.6 Interrupts and Exceptions 中断和异常 The 80386 has two mechanisms for interrupting program execution: ...

  4. LVS部分调度算法的适应场景分析

    1.轮叫调度算法(RR)假设所有服务器处理性能均相同,不管服务器的当前连接数和响应速度.该算法相对简单,不适用于服务器组中处理性能不一的情况,而且当请求服务时间变化比较大时,轮叫调度算法容易导致服务器 ...

  5. 如何知道自己的CPU支持SLAT

    因为WP8 SDK发布,很多WP8的开发者们也开始陆续安装WP8的SDK的,然而安装WP8的SDK有很多软件和硬件的要求,其中有一个就是——要求CPU支持二级地址转换(SLAT),如果CPU不支持二级 ...

  6. MFC cstring 型转化成 double型

    cstring szNum; GetDlgItemText(IDC_EDIT1, szNum); double Num; Num = _ttol(szNum); 转化成长整型 Num = _tstof ...

  7. 换个语言学一下 Golang (4)——变量与常量

    一.变量定义 所谓的变量就是一个拥有指定名称和类型的数据存储位置. //看一个例子 package main import ( "fmt" ) func main() { var ...

  8. 在Unity中对注册表的信息进行操作

      问题1 在对注册表进行操作时无法生成注册表相关的类  解决办法:     增加头文件using Microsft.Win32; 问题2                    在运行程序时报错同时注 ...

  9. Nginx +tomcat 实现负载均衡集群

    一.       工具   nginx-1.8.0 apache-tomcat-6.0.33 二.    目标   实现高性能负载均衡的Tomcat集群: 三.    步骤   1.首先下载Nginx ...

  10. UVALive 3026(KMP算法)

    UVALive 3026     KMP中next[]数组的应用: 题意:给出一个字符串,问该字符串每个前缀首字母的位置和该前缀的周期. 思路:裸KMP直接上就是了: 设该字符串为str,str字符串 ...