BZOJ 2728: [HNOI2012]与非(位运算)
题意
定义 NAND
(与非)运算,其运算结果为真当且仅当两个输入的布尔值不全为真,也就是 A NAND B = NOT(A AND B)
,运算位数不会超过 位,
给你 个整数 ,这些数能任意进行无数次与非运算,最后问能运算出多少个在 区间的数。
题解
参考了 kczno1 孔爷的题解。
这个运算初看不太优美,其实我们可以利用它的一些性质。
由于 A NAND A = NOT (A AND A) = NOT A
所以我们就可以得到了 NOT
(非) 运算。
进一步我们利用 NOT
,NOT(A NAND B) = NOT(NOT(A AND B)) = A AND B
,就可以得到了 AND
(与)运算。
这样这个运算就变得十分优秀了,我们就转化成进行 NOT
和 AND
然后我们就可以得到 所有二进制操作 了。
然后利用这个性质,我们就可以得到一个更加有用的性质。
对于第 位和第 位,如果所有 的第 位和第 位相同,那么最后的结果对于 这两位一定是一样的。
否则这两位的取值互不影响,可以任意取都能构造出一组合法方案。
我们就能把 位数划分成许多个等价类,每个等价类里面的元素取值都必须一样。
然后为了算 区间的答案,我们令 为 能凑出来的数。
那么答案为 。至于如何算 呢?我们按位考虑就行了。
-
具体的,如果枚举的位为 ,那么忽略。
-
如果为 ,假设这一位不能选,那么接下来以任意选而不会超也不会重复,所以方案数加上 ( 为接下来的集合的个数) 然后退出。
如果能选。要么不选,那么 ;要么将集合中的数全部选了,再接着枚举后面。、
复杂度是 的,不知道为什么 只开 。。。石乐志。
代码
__EOF__

本文链接:https://www.cnblogs.com/zjp-shadow/p/10096371.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】