GalaxyOJ 8699 午夜后的棒棒糖

挺高妙的题,思维套结论。

题意:给定 n 个数,求在其中选三个不交的子集,使得其异或和相等的方案数。

三个不交的集合异或和相等 两两异或和为 0

观察两个异或和为 0 的集合 S,T() 和答案有什么关系。

  • 有交但不包含

R=ST,则有 iRai=iSRai=iTRai

再考虑分出来这三个集合被计算了多少遍。发现一共有 6 中不同的 (S,T) 会得到这三个集合,也正好该集合的轮换数量。所以可以看作每对 (S,T) 都对答案产生了 1 的贡献。于是 A,B,C 都不为 的情况就计数完了。

  • else

因为三个非空集合的情况已经计数完了,无交的情况就考虑计数 A,B,C 有一个为空集的情况。发现相互包含本质上就是小集合并上另一个集合等于大集合。

和上面类似的,发现每个集合仍然被算了 6 次。

综上,得出结论:最多有一个为 的三元组个数 =S,T 的方案数。

剩下两种情况也很好算,就不展开讲了。

upd:发现其实有一种简单很多的做法……

发现 A,B,C 无交,所以 (A,B,C)(AB,BC) 双射。

所以答案即为 (S,T) 的个数的平方。这是个线性基经典问题,解决。

我是不是做过类似题来着?鉴定为打表技巧没有掌握好。@sk

posted @   yinhee  阅读(42)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话

阅读目录(Content)

此页目录为空

点击右上角即可分享
微信分享提示