BZOJ1660: [Usaco2006 Nov]Bad Hair Day 乱发节(单调栈)
2024-09-24 06:02:13
题意
Sol
单调栈板子题。。
找到向左第一个比他大的位置,然后判断一下就可以了
#include<bits/stdc++.h>
//#define int long long
#define LL long long
using namespace std;
const int MAXN = 1e6 + 10;
inline int read() {
char c = getchar(); int x = 0, f = 1;
while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * f;
}
int N, a[MAXN], st[MAXN], top;
signed main() {
N = read();
for(int i = 1; i <= N; i++) a[i] = read();
reverse(a + 1, a + N + 1);
LL ans = 0;
for(int i = 1; i <= N; i++) {
while(top && a[i] > a[st[top]]) top--;
ans += i - st[top] - 1;
st[++top] = i;
}
cout << ans;
return 0;
}
/*
5
5 5 5 5 5
*/
最新文章
- IIS6.0添加上.net4.0后,以前的.net系统出现“服务器应用程序不可用”的错误提示解决办法
- 使用JavaScript实现复选框全选与取消的功能
- eclipse里怎么用命令行输入args
- [SQL]oracle 的to_char、to_number、to_date用法
- 【转载】Ext中关于Ext.QuickTips.init()的使用
- 局域网Internet的共享
- 关于 css padding 的使用 padding会将使用该属性的元素撑开
- 算法战斗:给定一个号码与通配符问号W,问号代表一个随机数字。 给定的整数,得到X,和W它具有相同的长度。 问:多少整数协议W的形式和的比率X大?
- 12个很少被人知道的CSS事实
- 线上分享会.net框架“ABP”分享会总结
- lua语言自学知识点----Lua与.Net相互调用
- Lua在Redis中的应用
- oracle 内存不足处理
- linux系统下Nagios+rrdtool+Pnp4nagios监控环境的搭建
- TX锁处理
- javascript中的数据结构
- linux同步机制
- War Chess (hdu 3345)
- Linux打包、压缩与解压详解
- js04