bzoj1628 [Usaco2007 Demo]City skyline(单调栈)

Posted kafuuchino

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了bzoj1628 [Usaco2007 Demo]City skyline(单调栈)相关的知识,希望对你有一定的参考价值。

Description

技术分享图片

Input

第一行给出N,W
第二行到第N+1行:每行给出二个整数x,y,输入的x严格递增,并且第一个x总是1

Output

输出一个整数,表示城市中最少包含的建筑物数量

Sample Input

10 26
1 1
2 2
5 1
6 3
8 1
11 0
15 2
17 3
20 2
22 1

INPUT DETAILS:

The case mentioned above

Sample Output

6
 


题目的$w$没有意义
我们发现高度$h$出现一次时,答案+1
$h$在一个先增后降的序列中出现两次时,显然答案也只要+1
那么我们可以设$ans=n$
考虑维护一个单调递增栈,当某个数出现2次时,$ans-1$即可
技术分享图片
 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #define re register
 5 using namespace std;
 6 int n,q,h,w,st[50005],tp,ans;
 7 int main(){
 8     scanf("%d%d",&n,&w); ans=n;
 9     for(re int i=1;i<=n;++i){
10         scanf("%d%d",&q,&h);
11         while(tp&&st[tp]>h) --tp;
12         if(st[tp]==h) --ans;
13         else st[++tp]=h;        
14     }printf("%d",ans);
15     return 0;
16 }
View Code

 

 

以上是关于bzoj1628 [Usaco2007 Demo]City skyline(单调栈)的主要内容,如果未能解决你的问题,请参考以下文章

bzoj1629 [Usaco2007 Demo]Cow Acrobats

bzoj2023[Usaco2005 Nov]Ant Counting 数蚂蚁*&&bzoj1630[Usaco2007 Demo]Ant Counting*

bzoj1630/2023 [Usaco2007 Demo]Ant Counting

BZOJ 1695 [Usaco2007 Demo]Walk the Talk 链表+数学

刷水-贪心BZOJ1629-[Usaco2007 Demo]Cow Acrobats

bzoj1640[Usaco2007 Nov]Best Cow Line 队列变换*&&bzoj1692[Usaco2007 Dec]队列变换*