嗯嗯,这是一道线段树的题,询问区间内亮着的灯的个数,我们可以把区间修改的线段树改一下,原本的求和改成若有奇数次更改则取反(总长度-亮着的灯个数),而判断是否奇数次只要数组加一个delta的值,update的时候delta xor 1 就够了,代码如下. type tpoint=record l,r,sum,delta,mid:longint; end; var n,m,s,e,i,j,c,sum:longint; tree:array[..] of tpoint; procedure build…