qsgg and Subarray
题号:NC253360
时间限制:C/C++/Rust/Pascal 2秒,其他语言4秒
空间限制:C/C++/Rust/Pascal 256 M,其他语言512 M
64bit IO Format: %lld

题目描述

给定一个长度为 n 数组 A 。

你想知道有多少个子区间 [l,r] (1≤l≤r≤n) AND0,即 \oplus _{i=l}^{r}\ a_i = 0

此处\oplus表示位运算 and 操作。

输入描述:

输入共 2 行。

第一行一个整数表示 n\ (1≤n≤ 10^6)

接下来一行,n 个整数表示 a_i \ (0≤a_i≤10^9)

输出描述:

输出一个整数,表示满足条件的子区间 [l,r] 个数。
示例1

输入

复制
6
1 3 7 15 6 4

输出

复制
3

说明

三个区间,分别是 [1,5],[1,6],[2,6]