单哈希
1 | typedef unsigned long long ull; |
和自然溢出法不同的是,这种方法需要取模,并且是两套base mod。每次做哈希操作时,需要两套哈希值都一致,这就大大降低了冲突概率。但是据说常数比较大,并且写起来麻烦一些。
CF1320D
对于一个01串(2e5),给出两种操作:110<->011,可以执行任意多次,q(2e5)个提问,问这个串中某两个子串能否通过这两种操作互相转化。
分析可知,这种操作实际上就是把0左移或右移2位,也就是偶数次,那么如果这两个串中0出现的奇偶序列相同(比如第一个0都是奇数位上,第二个0都是偶数位上)那么就一定能互相转化成功,如果奇偶不同例如某两个0相邻,那是无法彼此转化的。所以问题就变成了,这两个子串中0出现的奇偶序列是否相同,这里是按照奇偶位置分别取1或2,不明白为啥0或1就会wa,,关于hash还有好多不懂的地方。
1 |
|