[NBUT 1646 Internet of Lights and Switches] 前缀异或和+二分
题意描述:N 个灯, M 个开关,每个开关可以控制多个灯。每个开关对应一个01串,第 i 位为0 表示 这个开关不能控制第i 盏灯, 为1 表示能够控制。初始灯是全亮的。你可以按一个连续区间的开关使得灯全灭,区间的长度必须是在[a, b],问 有多少种 方法可以使灯全灭。每个开关只能按一次。
解题思路:显然,按区间[L, R] 的开关等价于 先按一次[1, L - 1], 然后再按一次[L, R] 区间的开关。所以我们首先需要处理出前 i 盏灯的 前缀异或和, 用pre[] 表示。 要让灯全灭, 就相当于找出区间[L, R], 满足 这个区间 的异或和全为1。 也就等价于pre[R] ^ pre[L - 1] 全1。知道这个就简单很多了。我们只需要枚举区间左端点,然后二分区间右端点。然后求出区间长度就OK了。
#include <queue>
#include <cmath>
#include <cstdio>
#include <string>
#include <cstring>
#include <iostream>
#include <algorithm>