题目大意
给定 $L,R$,求从 $L$ 到 $R$ 的这 $R-L+1$ 个数中能选出多少个不同的子集,满足子集中所有的数的乘积是一个完全平方数。特别地,空集也算一种选法,定义其乘积为 $1$。
多测,$T \leq 100$
$1 \leq L \leq R \leq 10^7,\ \ \sum_{i=1}^T R_i-L_i+1 \leq 6 \times 10^7$
5s
题解
在 thu 门外哭哭的日子
感觉一开始没有这个方向的话就想不到这个方向了。。还是说我太菜了。。
【50%】$T \leq 10,\ \ \sum R_i-L_i+1 \leq 5000$
假设 $[1,maxR]$ 范围内的质数有 $pnum$ 个,分别为 $p_1,\cdots,p_{pnum}$。
把每个数字 $i$ 看成一个 $pnum$ 维 01 向量 $\vec{v_i}$,其中第 $j$ 维为 $1$ 当且仅当 $i$ 含有奇数个质因子 $p_j$。
那么原数相乘,相当于向量异或,于是就想到线性基。于是发现答案等于 $2^{R-L+1-基的数量}$。
然后优化,质数以 $\sqrt{maxR}$ 为界分为大质数和小质数,每个数最多含有 1 个大质数,因此出现过的大质数的位置一定是基,因此线性基就只用考虑小质数了。小质数共 446 个。
时间 $O(T (\sum R_i-L_i+1) \cdot 446 \cdot \frac{446}{64})。$
【100%】
思考第 11、12 个数据点的条件:$R_i-Li \geq 999990$,是要说什么呢?
是要引导发现一个性质:当区间长度 $R_i-L_i+1 \geq 2\sqrt{maxR}$ 时,所有小质数的位置都是基。
口胡证明:相当于证明所有的小质数都与别的质数线性独立。设有小质数 $p_1$,设质数 $p_2>p_1$。
当区间长度 $\geq 2\sqrt{maxR}$ 时,$p_1$ 至少出现两次了,且这两次里至少有一次是有 $p_1$ 而没有 $p_2$ 的,($p_1$ 出现的间隔为 $p_1$,这个间隔不可能使 $p_2$ 也出现两次。)然后区间内必然还有数是既不含 $p_1$ 也不含 $p_2$ 的。
也就是说,在不含 $p_2$ 的数里,既可以含有 $p_1$,也可以不含有 $p_1$,那么 $p_1$ 和 $p_2$ 就线性独立了。
$p_1$ 取遍所有的小质数,那么就有:所有的小质数都与别的质数线性独立,因此所有小质数的位置都是基。
这题可以偷懒直接把 $2\sqrt{maxR}$ 当成 $6000$ 省点常数。也就是区间长度 $\geq 6000$ 之后就不用做线性基了,可以扫一遍统计大质数然后输出。
那么时间就是 $O((\sum R_i-L_i+1)+T \cdot 6000 \cdot 446 \cdot \frac{446}{64})$,满打满算应该是跑不过的,但是它跑过去了。
代码
1 |
|