比较容易想的题目~
容易发现 点亮一种颜色的贡献=新增灯的数量-已经存在的边的条数。
用线段树维护并不容易。暴力的话复杂度是\(Q\cdot n\)的。
考虑根号分治 只单纯考虑度数
考虑大于B的点的话 需要思考一下贡献如何快速求出。
这类点显然只有\(\frac{2n}{B}\)个 统计大于对大于的点的话复杂度O(B).
考虑大于和小于的贡献发现不能暴力了 考虑这个小于其实是之前的小于的点对当前的贡献。
那么当前的小于可以提前对这些点的贡献进行统计就可以O(1)了。
那么此时\(B\cdot Q+\frac{2n}{B}\cdot Q\)当B取\(\sqrt{2n}\)时最优。
code
//#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include