P3917 异或序列

题目链接

按位考虑,计算有多少个区间异或值使得该位为1,因为该位为1才有贡献。

对每一位异或前缀,记录1,0的个数,易知最终结果是01的个数相乘。

cpp 复制代码
int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
	
	int n;
	cin >> n;

	vector<int> a(n);
	for (int i = 0; i < n; i++) {
		cin >> a[i];
	}    

	ll ans = 0;
	for (int i = 0; i < 30; i++) {
		int cnt[2]{1, 0};   //单独的1也有贡献,所以0的个数初始化为1
		int x = 0;

		for (int j = 0; j < n; j++) {
			x ^= a[j] >> i & 1;
			cnt[x]++;
		}
		ans += 1LL * cnt[0] * cnt[1] * (1 << i);
	}

	cout << ans << "\n";

    return 0;
}
相关推荐
feng_you_ying_li14 小时前
C++复习二,继承与多态
c++
小小de风呀14 小时前
de风——【从零开始学C++】(十一):list的基本使用和模拟实现
开发语言·c++·list
陌路2014 小时前
C++高级进阶--夯实进阶基础(1)
开发语言·c++
郝学胜-神的一滴16 小时前
中级OpenGL教程 008:精准控制高光光斑大小与强度
c++·unity·godot·three.js·图形学·opengl·unreal
牢姐与蒯16 小时前
c++数据结构之c++11(一)
数据结构·c++
折戟不必沉沙16 小时前
构造和析构函数能否是虚函数?能否调用虚函数?
c++
-To be number.wan17 小时前
算法日记 | STL- sort排序
c++·算法
不想写代码的星星17 小时前
编译期策略模式:当模板成为策略容器
c++
啦啦啦啦啦zzzz17 小时前
数据结构:平衡二叉树
数据结构·c++·二叉树
玖釉-17 小时前
Vulkan 中 Shader 的 vert、frag、mesh、comp 全面解析:作用、关系、特点与工程实践
开发语言·c++·windows·算法·图形渲染