题目链接

思路如下

这题恶心的枚举任意区间的 最大值及次最大值 ,正常的操作是,是很难实现的,但偏偏有个 单调栈这个动西,能够完成这个任务,跟单调队列相似,有单调 递增、递减的栈,这一题我们需要维护的是:递减栈。

对于这个单调递减栈:指的是从 从栈的底部 ——> 到 栈顶 元素值逐渐递减。

⚠️对于栈的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;
}

最新文章

  1. Android:TextView文字跑马灯的效果实现
  2. &lt;s:property value=&quot;&quot;/&gt; 怎么截取返回值的固定长度的字符串
  3. asp.net(c#)将彩色图片变灰阶图片
  4. MySQL 基础语句的练习2
  5. 编写高性能Web应用程序的10个技巧
  6. nth-child() 选择器
  7. CCNA 6.6
  8. OpenGL的学习与认识
  9. hdu 4144 状态压缩dp
  10. OpenJudge/Poj 2000 Gold Coins
  11. 搭建用友开发环境(基于碧桂园的nchome)
  12. 【转】Windows平台下Git服务器搭建
  13. Spark中的Scheduler
  14. HashMap和HashSet的源代码分析
  15. WPF:TreeView绑定
  16. 实验吧 php
  17. PAT 乙级 1049 数列的片段和(20) C++版
  18. select遍历list默认选中初始值
  19. RSA公钥加密,私钥解密的程序示例
  20. 首页焦点图myFocus插件

热门文章

  1. intel硬件视频加速介绍
  2. eetcode必要技巧--动态规划(一)
  3. LinkedHashMap源码解读
  4. 2020 还不会泡 Github 你就落伍了
  5. 轻装上阵Flink--在IDEA上开发基于Flink的实时数据流程序
  6. [vue/require-v-for-key] Elements in iteration expect to have &#39;v-bind:key&#39; directives.
  7. 使用MySql对IdentityServer4进行持久化
  8. 0318 guava并发工具
  9. DOTNET CORE源码分析之IOC容器结果获取内容补充
  10. linux环境下的时间编程