zoukankan      html  css  js  c++  java
  • bzoj 2741: 【FOTILE模拟赛】L 分塊+可持久化trie

    2741: 【FOTILE模拟赛】L

    Time Limit: 15 Sec  Memory Limit: 162 MB
    Submit: 1116  Solved: 292
    [Submit][Status]

    Description

    FOTILE得到了一个长为N的序列A,为了拯救地球,他希望知道某些区间内的最大的连续XOR和。
    即对于一个询问,你需要求出max(Ai xor Ai+1 xor Ai+2 ... xor Aj),其中l<=i<=j<=r。
    为了体现在线操作,对于一个询问(x,y):
    l = min ( ((x+lastans) mod N)+1 , ((y+lastans) mod N)+1 ).
    r = max ( ((x+lastans) mod N)+1 , ((y+lastans) mod N)+1 ).
    其中lastans是上次询问的答案,一开始为0。

    Input

    第一行两个整数N和M。
    第二行有N个正整数,其中第i个数为Ai,有多余空格。
    后M行每行两个数x,y表示一对询问。
     
     

    Output

     

    共M行,第i行一个正整数表示第i个询问的结果。

    Sample Input

    3 3
    1 4 3
    0 1
    0 1
    4 3


    Sample Output

    5
    7
    7


    HINT

    N=12000,M=6000,x,y,Ai在signed longint范围内。

       

      讀入原序列a,令b[i]=a[1]^a[2]^...^a[i],則b[i]^b[j]==a[i+1]^a[i+2]^...^a[j] (i<=j),遠問題轉化爲求區間兩數異或最大值。

      數集中異或最大值可以用trie O(nlogn)實現,這裏明顯會TLE,於是就可以對b進行分塊,然後實現查詢單數在區間中異或最大值,

      一個很神奇的可持久化trie樹,第一次編,但是隨便yy一下就出來了,給可持久化線段樹相似。

      本題還有一個易錯點,即強制離線的

          l = min ( ((x+lastans) mod N)+1 , ((y+lastans) mod N)+1 ).
          r = max ( ((x+lastans) mod N)+1 , ((y+lastans) mod N)+1 ).

      以上算法在lastans比較大時會爆int,這類問題簡直是防不勝防啊。。。

    by mhy12345(http://www.cnblogs.com/mhy12345/) 未经允许请勿转载

    本博客已停用,新博客地址:http://mhy12345.xyz

  • 相关阅读:
    0909我眼中的编译原理
    你要的所有数据源都在这里了!
    JAVA多线程和并发基础
    写的代码小有成就+今日总结--购买产品---20200508
    mysql数据库时区问题
    【Spring】——声明式事务配置详解
    SpringBoot整合阿里云OSS文件上传、下载、查看、删除
    一文看懂:网址,URL,域名,IP地址,DNS,域名解析
    git快速入门
    批处理框架spring batch基础知识介绍
  • 原文地址:https://www.cnblogs.com/mhy12345/p/4006596.html
Copyright © 2011-2022 走看看