POJ3250(单调栈)
Bad Hair Day
Time Limit: 2000MS | Memory Limit: 65536K | |
Total Submissions: 17614 | Accepted: 5937 |
Description
Some of Farmer John's N cows (1 ≤ N ≤ 80,000) are having a bad hair day! Since each cow is self-conscious about her messy hairstyle, FJ wants to count the number of other cows that can see the top of other cows' heads.
Each cow i has a specified height hi (1 ≤ hi ≤ 1,000,000,000) and is standing in a line of cows all facing east (to the right in our diagrams). Therefore, cow i can see the tops of the heads of cows in front of her (namely cows i+1, i+2, and so on), for as long as these cows are strictly shorter than cow i.
Consider this example:
== == - = Cows facing right -->= = == - = = == = = = = =1 2 3 4 5 6
Cow#1 can see the hairstyle of cows #2, 3, 4
Cow#2 can see no cow's hairstyle
Cow#3 can see the hairstyle of cow #4
Cow#4 can see no cow's hairstyle
Cow#5 can see the hairstyle of cow 6
Cow#6 can see no cows at all!
Let ci denote the number of cows whose hairstyle is visible from cow i; please compute the sum of c1 through cN.For this example, the desired is answer 3 + 0 + 1 + 0 + 1 + 0 = 5.
Input
Lines 2..N+1: Line i+1 contains a single integer that is the height of cow i.
Output
Sample Input
6 10 3 7 4 12 2
Sample Output
5
一群高度不完全相同的牛从左到右站成一排,每头牛只能看见它右边的比它矮的牛的发型,若遇到一头高度大于或等于它的牛,则无法继续看到这头牛后面的其他牛。
给出这些牛的高度,要求每头牛可以看到的牛的数量的和。
把要求作一下转换,其实就是要求每头牛被看到的次数之和。这个可以使用单调栈来解决。
从左到右依次读取当前牛的高度,从栈顶开始把高度小于或等于当前牛的高度的那些元素删除,此时栈中剩下的元素的数量就是可以看见当前牛的其他牛的数量。把这个数量加在一起,就可以得到最后的答案了。
单调栈的代码最后竟那么简洁。
1 //2016.8.23 2 #include<cstdio> 3 4 const int N = 80005; 5 int Stack[N], hi, top; 6 7 int main() 8 { 9 int n; 10 long long ans; 11 while(scanf("%d", &n)!=EOF) 12 { 13 ans = top = 0; 14 for(int i = 1; i <= n; i++) 15 { 16 scanf("%d", &hi); 17 while(top>0&&Stack[top-1]<=hi)top--; 18 ans += top; 19 Stack[top++] = hi; 20 } 21 printf("%lld\n", ans); 22 } 23 24 return 0; 25 }
转载于:https://www.cnblogs.com/Penn000/p/5800875.html
POJ3250(单调栈)相关推荐
- 线性结构 —— 单调栈与单调队列
[单调栈] 1.原理 单调栈,就是栈内元素保持一定单调性(单调递增或单调递减)的栈,即从栈底到栈顶单调递增或递减. 对于单调递增的栈,如果栈为空或入栈元素值大于等于栈顶元素值,则入栈:否则,若入栈会破 ...
- 单调栈与单调队列简单例题
单调栈与单调队列简单例题 单调栈: POJ3250 题意:有n只奶牛排成一列向右看,每头奶牛只能看到比自己矮的奶牛,即会被高的奶牛挡住后面,问共有多少只奶牛能被看到 思路:考虑每头奶牛能被前面牛看到的 ...
- 蒟蒻的ACM数据结构(四)-单调队列和单调栈
单调队列和单调栈 一.概念 二.实现 三.题目 单调队列 洛谷P1886 滑动窗口 解析 单调栈 [GXOI/GZOI2019]与或和 解析 POJ3250 Bad Hair Day 解析 POJ 2 ...
- POJ2796 Feel Good(单调栈)
题意: 给出一列数据,要求一个区间内最小值与区间内数据总和乘积最大值 要点: 还是单调栈,这次我自己写的,先做了几题比较简单的果然还是有效果的,这题也是一样,按点遍历,网上大神做的是直接遍历一次即可, ...
- 【单调栈 前缀和 异或】7.21序列求和
还要再细细思考的奇妙思路 题目描述 小A最近喜欢上了关于区间max的问题.她定义一个区间的价值是max(ai)(l<=i<=r)∗(alxoral+1xor...xorar)max(ai) ...
- 栈与队列7——单调栈结构(进阶问题)
题目 一个含有重复值的数组arr,找到每一个i位置左边和右边离i位置最近且值比arr[i]小的位置,返回所有相应的信息. 举例:arr={3,4,1,5,6,2,7},返回如下的二维数组作为结果:{{ ...
- 栈与队列7——单调栈结构(初阶问题)
题目 一个不含有重复值的数组arr,找到每一个i位置左边和右边离i位置最近且值比arr[i]小的位置,返回所有相应的信息. 举例:arr={3,4,1,5,6,2,7},返回如下的二维数组作为结果:{ ...
- 单调栈 or 线段树扫描线 ---- E. Delete a Segment [单调栈+二分] [扫描线处理空白位置的技巧乘2]
题目链接 题目大意: 给出nnn个线段代表集合,现在问若可以将其中任意一个线段删除,则能够形成最多多少个独立的集合(取并集后) 解题思路1: 首先我们先对线段按照起点排序 那么我们枚举删除的线段iii ...
- 后缀数组 ---- 2018~2019icpc焦作H题[后缀数组+st表+二分+单调栈]
题目链接 题目大意: 给出nnn个数,定义f[l,r]f[l,r]f[l,r]表示 区间[l,r][l,r][l,r]的最大值,求所有 子区间的最大值的和,要求相同的子区间只能算一次 比如数列 5 6 ...
最新文章
- 第五周周记(国庆第一天)
- 2048界面优化c语言,好玩的2048小游戏,C语言的代码分享给你,快来练习吧!
- oracle10g库连接报错
- Java NIO学习系列二:Channel
- 互联网推广方案:如何提高企业网站排名!
- scikit-learn学习笔记(二)load_files加载自己的文件
- 使用了BeanUtils的简单操作
- 图像处理之三---摄像头灰度值处理
- 七月算法机器学习2 数理统计与参数估计2
- 如何统计项目代码行数
- android 画图 工具下载,画板画图软件下载-画板画图 安卓版v1.1.0-PC6安卓网
- 指派问题java实现_指派问题及实现代码示例.ppt
- 微信小程序报错 RangeError: WebAssembly.Memory(): could not allocate memory
- 一夜没睡,仍然精力充沛——工作规划-2013.07.23
- IoT物联网嵌入式设备中30种常见传感器模块简介及原理讲解
- 半小时搞定Yolov5安装配置及使用(详细过程)
- 论文阅读:Hit-Detector: Hierarchical Trinity Architecture Search for Object Detection
- php画梯形,利用css来画出各种样式不同的梯形,html中梯形外框怎么做
- 北大计算机python教程_清华北大计算机系 联合推出的Java+Python1010集视频学习教程曝光...
- 从细节最初判断一家公司