CodeForces 280B(枚举 + 单调栈应用)
2024-10-08 23:36:54
题目链接
思路如下
这题恶心的枚举任意区间的 最大值及次最大值 ,正常的操作是,是很难实现的,但偏偏有个 单调栈
这个动西,能够完成这个任务,跟单调队列相似,有单调 递增、递减的栈,这一题我们需要维护的是:递减栈。
对于这个单调递减栈:指的是从 从栈的底部 ——> 到 栈顶 元素值逐渐递减。
⚠️对于栈的push操作:
- 栈为空的时候:直接压入元素
- 栈不为空的时候:1. 当所压入的元素小于栈顶的元素的时候,直接压入该元素 。。。。2.当所压入的元素大于栈顶的元素的时候,如果这个时候,我们把这个元素直接压入队列了,那么会破坏栈 的单调递减性,所以我们应该把在栈内比我们将要压入的元素大的 全部 弹出pop,然后在将该元素 压入栈。
题解如下
#include<iostream>
#include<stack>
using namespace std;
const int Len = 1e5 + 5;
int ar[Len];
int main()
{
int n;
scanf("%d",&n);
for(int i = 0; i < n; i ++)
scanf("%d",&ar[i]);
stack<int> st;
st.push(ar[0]);
int ans = -1;
for(int i = 1; i < n; i ++)
{
while(! st.empty() && ar[i] > st.top())
{
ans = max(ans , ar[i]^st.top());
st.pop();
}
if(! st.empty())
ans = max(ans , st.top()^ar[i]);
st.push(ar[i]);
}
printf("%d",ans);
return 0;
}
最新文章
- Android:TextView文字跑马灯的效果实现
- <;s:property value=";";/>; 怎么截取返回值的固定长度的字符串
- asp.net(c#)将彩色图片变灰阶图片
- MySQL 基础语句的练习2
- 编写高性能Web应用程序的10个技巧
- nth-child() 选择器
- CCNA 6.6
- OpenGL的学习与认识
- hdu 4144 状态压缩dp
- OpenJudge/Poj 2000 Gold Coins
- 搭建用友开发环境(基于碧桂园的nchome)
- 【转】Windows平台下Git服务器搭建
- Spark中的Scheduler
- HashMap和HashSet的源代码分析
- WPF:TreeView绑定
- 实验吧 php
- PAT 乙级 1049 数列的片段和(20) C++版
- select遍历list默认选中初始值
- RSA公钥加密,私钥解密的程序示例
- 首页焦点图myFocus插件
热门文章
- intel硬件视频加速介绍
- eetcode必要技巧--动态规划(一)
- LinkedHashMap源码解读
- 2020 还不会泡 Github 你就落伍了
- 轻装上阵Flink--在IDEA上开发基于Flink的实时数据流程序
- [vue/require-v-for-key] Elements in iteration expect to have &#39;v-bind:key&#39; directives.
- 使用MySql对IdentityServer4进行持久化
- 0318 guava并发工具
- DOTNET CORE源码分析之IOC容器结果获取内容补充
- linux环境下的时间编程