1 条题解
-
0
题意概括
维护 个频率()的开关状态,两个开启的频率若不互质就会干扰。
支持切换单个频率开关,查询区间 内是否存在一对开启的频率相互干扰。
核心思路
关键转化:
两个数不互质 ⇔ 它们有公共质因子。
因此,若区间内存在一个质数 ,使得 的倍数有至少 两个不同的开启频率,则答案為DA
,否则為NE
。
算法步骤
-
预处理
- 筛出 的质数,并求出每个数的质因子集合。
-
维护数据结构
- 对每个质数 ,用
set
或线段树维护是 的倍数且当前开启的频率集合。 - 全局维护一个
set
记录所有当前开启的频率。
- 对每个质数 ,用
-
查询处理
- 对询问 ,枚举 中某个开启的频率 的一个质因子 。
- 在 对应的开启频率集合中,查找是否存在另一个频率 且 。
- 若找到则输出
DA
,否则NE
。
-
优化
- 只需检查每个开启频率的最小质因子即可覆盖所有情况。
- 使用线段树维护每个质数 对应的最小/第二大开启位置,可 查询。
复杂度
- 预处理
- 每次操作 或
- 可通过
-
- 1
信息
- ID
- 3147
- 时间
- 2000ms
- 内存
- 512MiB
- 难度
- 8
- 标签
- 递交数
- 6
- 已通过
- 1
- 上传者