题意

题目链接

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
*/

最新文章

  1. IIS6.0添加上.net4.0后,以前的.net系统出现“服务器应用程序不可用”的错误提示解决办法
  2. 使用JavaScript实现复选框全选与取消的功能
  3. eclipse里怎么用命令行输入args
  4. [SQL]oracle 的to_char、to_number、to_date用法
  5. 【转载】Ext中关于Ext.QuickTips.init()的使用
  6. 局域网Internet的共享
  7. 关于 css padding 的使用 padding会将使用该属性的元素撑开
  8. 算法战斗:给定一个号码与通配符问号W,问号代表一个随机数字。 给定的整数,得到X,和W它具有相同的长度。 问:多少整数协议W的形式和的比率X大?
  9. 12个很少被人知道的CSS事实
  10. 线上分享会.net框架“ABP”分享会总结
  11. lua语言自学知识点----Lua与.Net相互调用
  12. Lua在Redis中的应用
  13. oracle 内存不足处理
  14. linux系统下Nagios+rrdtool+Pnp4nagios监控环境的搭建
  15. TX锁处理
  16. javascript中的数据结构
  17. linux同步机制
  18. War Chess (hdu 3345)
  19. Linux打包、压缩与解压详解
  20. js04

热门文章

  1. SpringBoot入门之事件监听
  2. windows下python3.6版本安装pygame
  3. Javac之glb与lub
  4. zookeeper基础知识
  5. ActiveMQ发布-订阅消息模式
  6. tomcat启动(五)Catalina分析-service.init
  7. pandas 去除NAN
  8. Java保存文本文件
  9. C#的SubString(int start,int end);
  10. 代码查看php是否已开启rewrite功能模块