AtCoder Beginner Contest 098 D - Xor Sum 2

D - Xor Sum 2


Time limit : 2sec / Memory limit : 1024MB

Score : 500 points

Problem Statement

There is an integer sequence A of length N.

Find the number of the pairs of integers l and r (1≤lrN) that satisfy the following condition:

  • Al xor Al+1 xor … xor Ar=Al + Al+1 + … + Ar

Here, xor denotes the bitwise exclusive OR.

 

Definition of XOR

 

Constraints

  • 1≤N≤2×105
  • 0≤Ai<220
  • All values in input are integers.

Input

Input is given from Standard Input in the following format:

N
A1 A2  AN

Output

Print the number of the pairs of integers l and r (1≤lrN) that satisfy the condition.


Sample Input 1

Copy
4
2 5 4 6

Sample Output 1

Copy
5

(l,r)=(1,1),(2,2),(3,3),(4,4) clearly satisfy the condition. (l,r)=(1,2) also satisfies the condition, since Axor A2=A1 + A2=7. There are no other pairs that satisfy the condition, so the answer is 5.


Sample Input 2

Copy
9
0 0 0 0 0 0 0 0 0

Sample Output 2

Copy
45

Sample Input 3

Copy
19
885 8 1 128 83 32 256 206 639 16 4 128 689 32 8 64 885 969 1

Sample Output 3

Copy
37


 1 #include <iostream>
 2 #include <cstdio>
 3 #include <algorithm>
 4 #include <cstdlib>
 5 #include <cstring>
 6 #include <string>
 7 #include <deque>
 8 using namespace std;
 9 #define  ll long long 
10 #define  N  200009
11 #define  gep(i,a,b)  for(int  i=a;i<=b;i++)
12 #define  gepp(i,a,b) for(int  i=a;i>=b;i--)
13 #define  gep1(i,a,b)  for(ll i=a;i<=b;i++)
14 #define  gepp1(i,a,b) for(ll i=a;i>=b;i--)    
15 #define  mem(a,b)  memset(a,b,sizeof(a))
16 int n,a[N];
17 ll sum[N],b[N];
18 /*
19 要想相加和等于异或和,就要区间的数二进制的每一位1只有一个
20 例如  1 2 4 8
21 如果 [l,r] 不可以,那么l++
22 如果[l,r] 可以,那么 r++
23 */
24 int  main()
25 {
26     scanf("%d",&n);
27     gep(i,1,n) {
28         scanf("%d",&a[i]);
29         sum[i]=sum[i-1]+a[i];
30         b[i]=b[i-1]^a[i];
31     }
32     int l=1;
33     ll ans=0;
34     gep(r,1,n){
35         for(;sum[r]-sum[l-1]!=(b[r]^b[l-1]);l++);//!=的优先级大于^,因此要加()
36         ans+=(r-l+1);
37     //[l,r] :每一次的可以就是多了[l,r],[l+1,r],[l+2,r]……[r,r]共(r-l+1)个区间
38     //可以一定是连续的,一旦不可以了就要改变r,l
39     }
40     printf("%lld\n",ans);
41     return  0;
42 }

 

posted on 2018-08-30 10:53  cltt  阅读(181)  评论(0编辑  收藏  举报

导航