首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >异或满足结合律吗_异或1⊕0的结果是

异或满足结合律吗_异或1⊕0的结果是

作者头像
全栈程序员站长
发布2022-09-22 11:02:54
发布2022-09-22 11:02:54
4520
举报

大家好,又见面了,我是你们的朋友全栈君。

给定一个非负整数序列 a,初始长度为 N。

有 M 个操作,有以下两种操作类型:

A x:添加操作,表示在序列末尾添加一个数 x,序列的长度 N 增大 1。 Q l r x:询问操作,你需要找到一个位置 p,满足 l≤p≤r,使得:a[p] xor a[p+1] xor … xor a[N] xor x 最大,输出这个最大值。 输入格式 第一行包含两个整数 N,M,含义如问题描述所示。

第二行包含 N 个非负整数,表示初始的序列 A。

接下来 M 行,每行描述一个操作,格式如题面所述。

输出格式 每个询问操作输出一个整数,表示询问的答案。

每个答案占一行。

数据范围 N,M≤3×105,0≤a[i]≤107。

代码语言:javascript
复制
输入样例:
5 5
2 6 4 3 6
A 1 
Q 3 5 4 
A 4 
Q 5 7 0 
Q 3 6 6 
输出样例:
4
5
6
代码语言:javascript
复制
#include<bits/stdc++.h>
using namespace std;
const int K = 25;
const int M = 6e6 + 10;
const int N = 6e6 + 10;
int trie[M * K][2],ctx;
int root[N],max_id[M * K];
int s[N];
int query(int l,int p,int C){ 
   
    if(root == 0)return 0;
    for(int i = 24;i >= 0;i --){ 
   
        int a = ((C >> i) & 1);
        if(trie[p][a ^ 1] && max_id[trie[p][a ^ 1]] >= l){ 
   
            p = trie[p][a ^ 1];
        }else { 
   
            p = trie[p][a];
        }
    }
    return s[max_id[p]];
}
void insert(int bit,int x,int p,int q,int d){ 
   
    if(bit < 0){ 
   
        max_id[p] = d;
        return;
    }else{ 
   
        int a = ((x >> bit) & 1);
        if(q)trie[p][a ^ 1] = trie[q][a ^ 1];
        trie[p][a] = ++ ctx;
        int t = p;
        q = trie[q][a],p = trie[p][a];
        insert(bit - 1,x,p,q,d);
        max_id[t] = max(max_id[trie[t][0]],max_id[trie[t][1]]);
    }
}
int main(){ 
   
    int n,m;
    cin>>n>>m;
    int now = 0,x;
    int e = 0;
    for(int i = 0;i < n;i ++){ 
   
        scanf("%d",&x);
        root[i + 1] = ++ ctx;
        insert(24,x ^ now,root[i + 1],root[i],i + 1);
        now ^= x;
        s[i + 1] = now;
        e = x;
    }
    char t;
    int l,r;
    int c = 1;
    for(int i = 0;i < m; i++){ 
   
        scanf(" %c",&t);
        if(t == 'A'){ 
   
            scanf("%d",&x);
            root[n + c] = ++ ctx;
            insert(24,now ^ x,root[n + c],root[n + c - 1],n + c);
            now ^= x;
            s[n + c] = now;
            e = x;
            c ++;
        }
        else { 
   
            scanf("%d %d %d",&l,&r,&x);
            printf("%d\n",(query(l - 1,root[r - 1],now ^ x) ^ (now ^ x)));
        }
    }
}

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/168600.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档