题目大意:给定一个长度为 N 的序列,每个位置有一个权值,求 $$\sum\limits_{1\le i\le j\le n}(a_i\oplus a_{i+1}...\oplus a_j)$$ 的值。
题解:
解法1:从整体考虑。
先预处理出序列的前缀异或和。根据和式的性质可知,对于任意两个点 i,j 的组合均会计入答案贡献,而异或值为 1 才会对答案产生贡献。因此,统计出对于32位中的每一位来说,前缀和序列中该位为 1 的个数。最后根据组合计数原理,每一位对答案的贡献为该位 1 的个数乘以该位 0 的个数乘以对应的 2 的幂即可。
代码如下
#include
#define fi first
#define se second
#define pb push_back
#define mp make_pair
#define all(x) x.begin(),x.end()
#define cls(a,b) memset(a,b,sizeof(a))
using namespace std;
typedef long long ll;
typedef pair P;
const int dx[]={0,1,0,-1};
const int dy[]={1,0,-1,0};
const int mod=1e9+7;
const int inf=0x3f3f3f3f;
const int maxn=1e5+10;
const double eps=1e-6;
inline ll gcd(ll a,ll b){retu