CodeForces526F:Pudding Monsters (分治)
In this problem you will meet the simplified model of game Pudding Monsters.
An important process in developing any game is creating levels. A game field in Pudding Monsters is an n × n rectangular grid, n of its cells contain monsters and some other cells contain game objects. The gameplay is about moving the monsters around the field. When two monsters are touching each other, they glue together into a single big one (as they are from pudding, remember?).
Statistics showed that the most interesting maps appear if initially each row and each column contains exactly one monster and the rest of map specifics is set up by the correct positioning of the other game objects.
A technique that's widely used to make the development process more efficient is reusing the available resources. For example, if there is a large n × n map, you can choose in it a smaller k × k square part, containing exactly k monsters and suggest it as a simplified version of the original map.
You wonder how many ways there are to choose in the initial map a k × k (1 ≤ k ≤ n) square fragment, containing exactly k pudding monsters. Calculate this number.
Input
The first line contains a single integer n (1 ≤ n ≤ 3 × 105) — the size of the initial field.
Next n lines contain the coordinates of the cells initially containing monsters. The i-th of the next lines contains two numbers ri, ci (1 ≤ ri, ci ≤ n) — the row number and the column number of the cell that initially contains the i-th monster.
It is guaranteed that all ri are distinct numbers and all ci are distinct numbers.
Output
Print the number of distinct square fragments of the original field that can form a new map.
Examples
5
1 1
4 3
3 2
2 4
5 5
10
题意:给定N*N的棋盘,以及N个棋子放置情况,保证每一行,每一列只有一个棋子。问现在有多少个子正方形,满足每一行每一列都有一个棋子。
思路:以x坐标为第一关键字,转化为一维数组,如样例(1,4,2,3,5),然后问题就成了有多少个练习子区间[i,j],满足i-j=max-min,棋子max和min是区间最大和最小值。 显然分治可以搞,问题转化为多个子问题:求跨过Mid的区间,满足i-j=max-min。
如何线性地解决子问题:由于max和min都是单调的,我们枚举i或者j,然后验证另外一个是否在当前子区间区间里,同时满足max和min的关系,累加答案。
#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
const int maxn=3e5+;
int mx[maxn],mn[maxn],sum[maxn<<];
int a[maxn],N; ll ans;
void solve(int L,int R)
{
if(L==R){ ans++; return ;}
int Mid=(L+R)/;
solve(L,Mid); solve(Mid+,R);
mx[Mid]=mn[Mid]=a[Mid]; mx[Mid+]=mn[Mid+]=a[Mid+];
for(int i=Mid-;i>=L;i--) mx[i]=max(mx[i+],a[i]);//预处理
for(int i=Mid-;i>=L;i--) mn[i]=min(mn[i+],a[i]);
for(int i=Mid+;i<=R;i++) mx[i]=max(mx[i-],a[i]);
for(int i=Mid+;i<=R;i++) mn[i]=min(mn[i-],a[i]); for(int i=Mid;i>=L;i--){ //都在左测
int j=mx[i]-mn[i]+i;
if(j<=R&&j>Mid&&mx[j]<mx[i]&&mn[j]>mn[i]) ans++;
}
for(int i=Mid+;i<=R;i++){ //都在右侧
int j=i-mx[i]+mn[i];
if(j<=Mid&&j>=L&&mx[j]<mx[i]&&mn[j]>mn[i]) ans++;
}
int j=Mid+,k=Mid+;
for(int i=Mid;i>=L;i--){ //左小右大
while(j<=R&&mn[j]>mn[i]) sum[mx[j]-j+N]++,j++;
while(k< j&&mx[k]<mx[i]) sum[mx[k]-k+N]--,k++;
ans+=(ll)sum[mn[i]-i+N];
}
while(k<j) sum[mx[k]-k+N]--,k++;
j=Mid,k=Mid;
for(int i=Mid+;i<=R;i++){ //左大右小
while(j>=L&&mn[j]>mn[i]) sum[mx[j]+j]++,j--;
while(k> j&&mx[k]<mx[i]) sum[mx[k]+k]--,k--;
ans+=(ll)sum[mn[i]+i];
}
while(k>j) sum[mx[k]+k]--,k--;
}
int main()
{
int x,y,i,j;
scanf("%d",&N);
for(i=;i<=N;i++) scanf("%d%d",&x,&y) ,a[x]=y;
solve(,N);
printf("%lld\n",ans);
return ;
}
CodeForces526F:Pudding Monsters (分治)的更多相关文章
- [Codeforces526F]Pudding Monsters 分治
F. Pudding Monsters time limit per test 2 seconds memory limit per test 256 megabytes In this proble ...
- 【CF526F】Pudding Monsters cdq分治
[CF526F]Pudding Monsters 题意:给你一个排列$p_i$,问你有对少个区间的值域段是连续的. $n\le 3\times 10^5$ 题解:bzoj3745 Norma 的弱化版 ...
- Codeforces 526F Pudding Monsters - CDQ分治 - 桶排序
In this problem you will meet the simplified model of game Pudding Monsters. An important process in ...
- CF526F Pudding Monsters
CF526F Pudding Monsters 题目大意:给出一个\(n* n\)的棋盘,其中有\(n\)个格子包含棋子. 每行每列恰有一个棋子. 求\(k*k\)的恰好包含\(k\)枚棋子的子矩形个 ...
- 「CF526F」 Pudding Monsters
CF526F Pudding Monsters 传送门 模型转换:对于一个 \(n\times n\) 的棋盘,若每行每列仅有一个棋子,令 \(a_x=y\),则 \(a\) 为一个排列. 转换成排列 ...
- Pudding Monsters CodeForces - 526F (分治, 双指针)
大意: n*n棋盘, n个点有怪兽, 求有多少边长为k的正方形内恰好有k只怪兽, 输出k=1,...,n时的答案和. 等价于给定n排列, 对于任意一个长为$k$的区间, 若最大值最小值的差恰好为k, ...
- [Codeforce526F]:Pudding Monsters(分治)
题目传送门 题目描述 由于各种原因,桐人现在被困在Under World(以下简称UW)中,而UW马上要迎来最终的压力测试——魔界入侵.唯一一个神一般存在的Administrator被消灭了,靠原本的 ...
- 奇袭 CodeForces 526F Pudding Monsters 题解
考场上没有认真审题,没有看到该题目的特殊之处: 保证每一行和每一列都恰有一只军队,即每一个Xi和每一个Yi都是不一样 的. 于是无论如何也想不到复杂度小于$O(n^3)$的算法, 只好打一个二维前缀和 ...
- 【CF526F】Pudding Monsters
题意: 给你一个排列pi,问你有对少个区间的值域段是连续的. n≤3e5 题解: bzoj3745
随机推荐
- Hibernate注解详解
一.实体Bean 每个持久化POJO类都是一个实体Bean, 通过在类的定义中使用 @Entity 注解来进行声明. 声明实体Bean @Entitypublic class Flightimplem ...
- iOS -- MBProgressHUB
高级: http://www.jianshu.com/p/485b8d75ccd4 //只有小菊花 - (void)indeterminateExample { // Show the HUD on ...
- 【转载】Websocket学习
首先是在Tomcat里面看到Websocket的演示.很有意思. http://localhost:8080/examples/websocket/index.xhtml 里面有: Echo exam ...
- [c++菜鸟]《Accelerate C++》读书笔记
第0章 开始学习C++ 1.<<的行为取决于它的操作数类型,<<会把它的右操作数的字符写到左操作数所指示的流中,他是结果就是它的左操作数. 2.std::endl是一个控制器, ...
- Unity3D:Gizmos画圆(原创)
Unity3D引擎技术交流QQ群:[21568554] Gizmos是场景视图里的一个可视化调试工具. 在做项目过程中.我们常常会用到它,比如:绘制一条射线等. Unity3D 4.2版本号截至.眼下 ...
- discuz X3.1+Apache2.2+php-5.2.17+mysql5.6.14+Discuz_X3.1
discuz X3.1+Apache2.2.25+php-5.2.17+mysql5.6.14+Discuz_X3.1 一.准备 1.httpd-2.2.25-win32-x86-no_ssl.msi ...
- 百度地图 创建 自定义控件(vue)
1.组件代码 Bmap.vue <!-- 离线地图 组件 --> <template> <div id="map" :style="styl ...
- vue2 + typescript2 自定义过滤器
1.定义一个过滤器 // color-directive.ts import { DirectiveOptions } from 'vue' const directive: DirectiveOpt ...
- Odoo10对套件的处理
Odoo10对套件的处理更强, 除了老版本支持的 销售套件, 按组件出货: 现在还增加了 采购套件, 按组件进货 建立 组件产品 KIT 设置 虚件BOM 测试, ...
- Andriod三步学会安卓自己定义视图及其属性
第一步:自己定义属性 第二步:自己定义控件解析属性 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcm5adW9adW8=/font/5a6L5L2T/fo ...