【模拟】Vijos P1926 紫色的手链

题目链接:

  https://vijos.org/p/1926

题目大意

  给n个数(n<=100 000),求任意区间的最大值异或次大值的最大值。

题目思路:

  【模拟】【单调栈】

  我们维护一个严格单调递减队列,存放当前的数字,初始为前两个数字。

  每当加入新的元素时,依次与栈头的元素比较,每次比较更新ans(当作该元素与栈头元素构成的区间解,因为是严格单调递减序列,所以这两个元素是最大和次大的,否则栈头已经被弹出),如果新的元素比栈头元素大,就将栈头元素弹出,重复以上的比较,更新解,弹出栈头操作,直到结束。因为每个数字只会进栈出栈一次,所以时间复杂度是O(n)。

 (说得有点拙计,如果没看懂可以自己稍微画画样例什么的,或者留言~) 

 1 //
 2 //by coolxxx
 3 //
 4 #include<iostream>
 5 #include<algorithm>
 6 #include<string>
 7 #include<iomanip>
 8 #include<memory.h>
 9 #include<time.h>
10 #include<stdio.h>
11 #include<stdlib.h>
12 #include<string.h>
13 #include<stdbool.h>
14 #include<math.h>
15 #define min(a,b) ((a)<(b)?(a):(b))
16 #define max(a,b) ((a)>(b)?(a):(b))
17 #define abs(a) ((a)>0?(a):(-(a)))
18 #define lowbit(a) (a&(-a))
19 #define sqr(a) (a)*(a)
20 #define swap(a,b) (a)^=(b),(b)^=(a),(a)^=(b)
21 #define eps 1e-8
22 #define MAX 0x7f7f7f7f
23 #define INF 20000
24 #define PI 3.1415926535897
25 #define N 100004
26 using namespace std;
27 int n,m,lll,ans,cas;
28 int a[N];
29 int main()
30 {
31     #ifndef ONLINE_JUDGE
32 //    freopen("1.txt","r",stdin);
33 //    freopen("2.txt","w",stdout);
34     #endif
35     int i,j,k;
36     while(~scanf("%d",&n) && n)
37     {
38         scanf("%d%d",&a[1],&a[2]);
39         lll=2;ans=a[1]^a[2];
40         for(i=3;i<=n;i++)
41         {
42             scanf("%d",&k);
43             while(lll>0 && k>a[lll])j=a[lll--]^k,ans=max(ans,j);
44             if(lll>0)ans=max(ans,a[lll]^k);
45             a[++lll]=k;
46         }
47         printf("%d\n",ans);
48     }
49     return 0;
50 }
51
52
53 /*
54 //
55
56 //
57 */

时间: 2024-12-07 23:06:26

【模拟】Vijos P1926 紫色的手链的相关文章

紫色的手链(求最大值和次大值的异或值最大)

描述 那是木姑娘十七岁时,我送给她的生日礼物.(后来手链也成为了我最喜欢的出题媒介) 记得最初买的手链,由n段紫色的珠子构成,每一颗珠子都被赋予了一种价值评价w[i]. 为了木姑娘,我只惋惜自己不能摘下漫天繁星送给她. 不过我并没有将整个手链都送出去,木姑娘的手腕是纤细的.我只需要截取一个子段就可以了,长度无论多少都可以. 不过我希望,这个子段的最大值异或次大值可以最大,这样或许木姑娘会更喜欢吧.(这里次大是说严格次大) 格式 输入格式 第一行一个数n 第二行n个数,依次表示这个序列w[1],w

【RQNOJ】460 诺诺的队列

[题目大意] 求所有数对(i,j)满足任意a[k]<=a[i]且a[k]<=a[j]. 形象地说,就是有一群人站成一列,每个人有一定的身高,然后问有多少对人可以互相看得到. 把数对(i,j)简单地称之为看得到的数对. [解析]单调栈 先借用一下以前做的题:[Vijos]1926 紫色的手链,求任意区间最大值异或次大值的最大值. 回顾一下单调栈,就是存储从高到低递减的单调数据的栈. 借用以前的做法,求出来的东西相对于所有看得到的数对,对于所有a[i]相等的看得见的数对,只算了一次. 于是其实每次

【模拟】Vijos P1062 迎春舞会之交谊舞

题目链接: https://vijos.org/p/1062 题目大意: 一群男女站成一排,一男一女配对,女的只找左边第一个空闲的男生,给定前n个女生左边的额男生个数,问前n个女生到男伴之间共有几个男生.(n<=1500 女生左侧男生231内) 题目思路: [模拟] 每个女生只找左边的最靠近的闲置男生,所以每当女生左边的男生数变化的时候就说明队伍里加入了新的男生,而这些男生只会影响右侧的女生. 所以我一开始想到,把男生分成好多群,加入一个女生完把最靠近她的男生群最右的男生配对给这个女生,然后该男

Vijos P1114 FBI树【DFS模拟,二叉树入门】

描述 我们可以把由“0”和“1”组成的字符串分为三类:全“0”串称为B串,全“1”串称为I串,既含“0”又含“1”的串则称为F串. FBI树是一种二叉树1,它的结点类型也包括F结点,B结点和I结点三种.由一个长度为2^N的“01”串S可以构造出一棵FBI树T,递归的构造方法如下: 1) T的根结点为R,其类型与串S的类型相同: 2) 若串S的长度大于1,将串S从中间分开,分为等长的左右子串S1和S2:由左子串S1构造R的左子树T1,由右子串S2构造R的右子树T2. 现在给定一个长度为2^N的“0

Vijos P1103 校门外的树【线段树,模拟】

校门外的树 描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,……,L,都种有一棵树. 由于马路上有一些区域要用来建地铁.这些区域用它们在数轴上的起始点和终止点表示. 已知任一区域的起始点和终止点的坐标都是整数,区域之间可能有重合的部分.现在要把这些区域中的树(包括区域端点处的两棵树)移走.你的任务是计算将这些树都移走后,马路上还有多少棵树. 格式 输入格式 输入的

【模拟】Vijos P1005 超长数字串

题目链接: https://vijos.org/p/1005 题目大意: 无限的正整数按顺序拼接成字符串S(S=12345678910111213...),给你一个字符串A(len<=200)求这个字符串在S中最早出现的位置. (答案超过long long ,无法用KMP,不要相信标签) 题目思路: [模拟] 这题简直了!!!!!!大模拟啊.细节超级多.疯狂TLE+WA+RE了17次才AC. 第一次写了一整天没写过,放了好久,昨天又写了一整天(哎效率低下.) 首先分两种普遍的情况和两种特殊情况考

Vijos P1785 同学排序【模拟】

同学排序 描述 现有m位同学,第1位同学为1号,第2位同学为2号,依次第m位同学为m号.要求双号的学生站出来,然后余下的重新组合,组合完后,再次让双号的学生站出来,重复n次,问这时有多少同学出来站着? 样例1 样例输入1 1989 5 样例输出1 1926 限制 1s 提示 [数据范围] 1≤n≤10 100≤m≤100000 题目链接:https://vijos.org/p/1785 分析:站出序号为偶数的人,如果总人数为奇数,剩余人数向上取整再折半就好了! 下面给出AC代码: 1 #incl

vijos国庆节模拟赛之繁星春水

A.闪烁的繁星 题目:https://vijos.org/p/1881 题解:貌似做过小白逛公园或者序列操作都可以秒出吧,就是pushup函数比较麻烦,不过仔细想一想就知道了. 代码: 1 #include<cstdio> 2 #include<cstdlib> 3 #include<cmath> 4 #include<cstring> 5 #include<algorithm> 6 #include<iostream> 7 #inc

【排序+模拟】vijos 1816 统计数字

标签:NOIP提高组2007 描述 某次科研调查时得到了n个自然数,每个数均不超过1500000000(1.5*10^9).已知不相同的数不超过10000个,现在需要统计这些自然数各自出现的次数,并按照自然数从小到大的顺序输出统计结果. 格式 输入格式 第1行是整数n(1<=n<=200000),表示自然数的个数. 第2~n+1行每行一个自然数. 输出格式 输出包含m行(m为n个自然数中不相同数的个数),按照自然数从小到大的顺序输出.每行输出两个整数,分别是自然数和该数出现的次数,其间用一个空