题目链接:http://codeforces.com/problemset/problem/617/E

E. XOR and Favorite Number
time limit per test

4 seconds

memory limit per test

256 megabytes

input

standard input

output

standard output

Bob has a favorite number k and ai of
length n. Now he asks you to answer m queries.
Each query is given by a pair li and ri and
asks you to count the number of pairs of integers i and j,
such that l ≤ i ≤ j ≤ r and the xor of the numbers ai, ai + 1, ..., aj is
equal to k.

Input

The first line of the input contains integers nm and k (1 ≤ n, m ≤ 100 000, 0 ≤ k ≤ 1 000 000) —
the length of the array, the number of queries and Bob's favorite number respectively.

The second line contains n integers ai (0 ≤ ai ≤ 1 000 000) —
Bob's array.

Then m lines follow. The i-th
line contains integers li and ri (1 ≤ li ≤ ri ≤ n) —
the parameters of the i-th query.

Output

Print m lines, answer the queries in the order they appear in the input.

Examples
input
  1. 6 2 3
  2. 1 2 1 1 0 3
  3. 1 6
  4. 3 5
output
  1. 7
  2. 0
input
  1. 5 3 1
  2. 1 1 1 1 1
  3. 1 5
  4. 2 4
  5. 1 3
output
  1. 9
  2. 4
  3. 4
Note

In the first sample the suitable pairs of i and j for the first query are: (1, 2), (1, 4), (1, 5), (2, 3), (3, 6), (5, 6), (6, 6). Not a single of these pairs is suitable for the second query.

In the second sample xor equals 1 for all subarrays of an odd length.

题意:

给出一个序列,作m此查询,每次查询的内容为:在区间[l, r]内,有多少个子区间的异或和为k?

题解:

莫队算法:解决区间询问的离线方法,时间复杂度:O(n^1.5)。

代码如下:

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. typedef long long LL;
  4. const int INF = 2e9;
  5. const LL LNF = 9e18;
  6. const int mod = 1e9+;
  7. const int maxn = 1e5+;
  8.  
  9. int n, m, k, w, a[maxn];
  10. LL sum, ans[maxn], c[];
  11. //a[i]为前缀异或和,c[i]为在当前区间内,前缀异或和(从1开始)为i的个数。
  12. //可知:a[l-1]^a[r] = val[l]^val[l+1]^………^val[r]
  13.  
  14. struct node
  15. {
  16. int l, r, id;
  17. bool operator<(const node &x)const{
  18. if(l/w==x.l/w) return r<x.r;
  19. return l/w<x.l/w;
  20. }
  21. }q[maxn];
  22.  
  23. void del(int i)
  24. {
  25. c[a[i]]--;
  26. sum -= c[a[i]^k];
  27. }
  28.  
  29. void add(int i)
  30. {
  31. sum += c[a[i]^k];
  32. c[a[i]]++;
  33. }
  34.  
  35. int main()
  36. {
  37. scanf("%d%d%d",&n,&m,&k);
  38. for(int i = ; i<=n; i++)
  39. {
  40. scanf("%d",&a[i]);
  41. a[i] ^= a[i-];
  42. }
  43. for(int i = ; i<=m; i++)
  44. {
  45. scanf("%d%d",&q[i].l,&q[i].r);
  46. q[i].id = i;
  47. }
  48.  
  49. w = sqrt(n);
  50. sort(q+,q++m);
  51.  
  52. int L = , R = ;
  53. c[] = , sum = ;
  54. for(int i = ; i<=m; i++)
  55. {
  56. while(L<q[i].l) del(L-), L++;
  57. while(L>q[i].l) L--, add(L-);
  58. while(R<q[i].r) R++, add(R);
  59. while(R>q[i].r) del(R), R--;
  60. ans[q[i].id] = sum;
  61. }
  62.  
  63. for(int i = ; i<=m; i++)
  64. printf("%lld\n",ans[i]);
  65. return ;
  66. }

Codeforces Round #340 (Div. 2) E. XOR and Favorite Number —— 莫队算法的更多相关文章

  1. Codeforces Round #340 (Div. 2) E. XOR and Favorite Number 莫队算法

    E. XOR and Favorite Number 题目连接: http://www.codeforces.com/contest/617/problem/E Descriptionww.co Bo ...

  2. Codeforces Round #340 (Div. 2) E XOR and Favorite Number 莫队板子

    #include<bits/stdc++.h> using namespace std; <<; struct node{ int l,r; int id; }q[N]; in ...

  3. Codeforces Round #340 (Div. 2) E. XOR and Favorite Number 【莫队算法 + 异或和前缀和的巧妙】

    任意门:http://codeforces.com/problemset/problem/617/E E. XOR and Favorite Number time limit per test 4 ...

  4. Codeforces Round #340 (Div. 2) E. XOR and Favorite Number (莫队)

    题目链接:http://codeforces.com/contest/617/problem/E 题目大意:有n个数和m次查询,每次查询区间[l, r]问满足ai ^ ai+1 ^ ... ^ aj ...

  5. Codeforces Round #340 (Div. 2) E. XOR and Favorite Number

    time limit per test 4 seconds memory limit per test 256 megabytes input standard input output standa ...

  6. codeforces 617E E. XOR and Favorite Number(莫队算法)

    题目链接: E. XOR and Favorite Number time limit per test 4 seconds memory limit per test 256 megabytes i ...

  7. Codeforces617 E . XOR and Favorite Number(莫队算法)

    XOR and Favorite Number time limit per test: 4 seconds memory limit per test: 256 megabytes input: s ...

  8. CodeForces - 617E XOR and Favorite Number 莫队算法

    https://vjudge.net/problem/CodeForces-617E 题意,给你n个数ax,m个询问Ly,Ry,  问LR内有几对i,j,使得ai^...^ aj =k. 题解:第一道 ...

  9. [Codeforces Round #340 (Div. 2)]

    [Codeforces Round #340 (Div. 2)] vp了一场cf..(打不了深夜的场啊!!) A.Elephant 水题,直接贪心,能用5步走5步. B.Chocolate 乘法原理计 ...

随机推荐

  1. 猴子都能懂的git教程链接

    http://backlogtool.com/git-guide/cn/intro/intro1_1.html

  2. Java 获取当前时间及实现时间倒计时功能

    引言 在一些项目中或是一些特殊的业务场景中,需要用到显示系统的当前时间,以及一些固定的时间倒计时,时间到后做一些什么事情的业务 .接下来咱们就具体看看代码是怎么实现的: <%@ page lan ...

  3. Data.FireDACJSONReflect单元不支持跨平台

    Data.FireDACJSONReflect不支持跨平台 Data.FireDACJSONReflect里面:IFDJSONDeltasApplyUpdates,TFDJSONDeltas,TFDJ ...

  4. TIdHTTPServer制作REST中间件

    TIdHTTPServer制作REST中间件 使用DELPHI7+INDY9开发 // 陈新光 2017-2-21// LIS数据同步服务器// 浏览器输入:http://127.0.0.1:8000 ...

  5. 奇酷手机显示Log

    1.在桌面点击拨号,在拨号盘输入“*20121220#”,进入工程模式;2.看到日志输出等级,点进去 Log print enable 选 enable Java log level 选 LOGV C ...

  6. paramiko获取远程主机的环境变量

    本文的情况,不同的linux系统版本,表现可能不同. 问题:默认情况下,paramiko在远程主机上执行命令的时候,命令的搜索路径为(/usr/local/bin:/bin:/usr/bin),这样我 ...

  7. 算法之美--2.3.1 Z字形编排问题

    2016-12-08   00:23:11 写在前面的话:万事贵在坚持,万事开头难,有很多的东西要学,要知道主次,讲究效率,大的方向对就行!坚持........ 一.图像压缩编码中的Z字排序 JPEG ...

  8. 转: 如何选CDN:互联网大直播时代的CDN选择指南

    from:  http://www.chnvideo.com/blog-classic-cdn.html SRS 编码器   如何选CDN:互联网大直播时代的CDN选择指南 CDN是一个服务型的公司, ...

  9. 别样JAVA学习(五)继承上(1.1)Object类toString()

    接下来说完equals以后,我们学习接下来的toString(), Java又觉得全部对象不光具有比較性, 还能使对象变成字符串被打印. 出现 曾经前面显示的是数组.如今显示的是这个对象所属的类. 紧 ...

  10. bootstrap到底是用来做什么的(概念)

    Bootstrap官网:http://v3.bootcss.com/ Bootstrap是Twitter推出的一个用于前端开发的开源工具包.它由Twitter的设计师Mark Otto和Jacob T ...