社区讨论

10分求救

P3870[TJOI2009] 开关参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@lo2ylm0o
此快照首次捕获于
2023/10/23 21:54
2 年前
此快照最后确认于
2023/10/23 21:54
2 年前
查看原帖
CPP
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
const int N = 1e5 + 10;
int n , m;
struct tree{
	int l , r , sum , lazy;
}tr[4 * N];
void pushup(int u)
{
	tr[u].sum = tr[u << 1].sum + tr[u << 1 | 1].sum;
}
void pushdown(int u)
{
	if(tr[u].lazy)
	{
		tr[u << 1].lazy += tr[u].lazy % 2;
		tr[u << 1 | 1].lazy += tr[u].lazy % 2;
		tr[u << 1].sum = !tr[u << 1].lazy ? tr[u << 1].sum : tr[u << 1].r - tr[u << 1].l + 1 - tr[u << 1].sum;
		tr[u << 1 | 1].sum = !tr[u << 1 | 1].lazy ? tr[u << 1 | 1].sum : tr[u << 1 | 1].r - tr[u << 1 | 1].l + 1 - tr[u << 1 | 1].sum;	
		tr[u].lazy = 0;
	}
}
void modify(int u,int l,int r)
{
	if(tr[u].l >= l && tr[u].r <= r)
	{
		tr[u].lazy ++;
		tr[u].sum = tr[u].r - tr[u].l + 1 - tr[u].sum;
	}
	else
	{
		pushdown(u);
		int mid = tr[u].l + tr[u].r >> 1;
		if(l <= mid) modify(u << 1 , l , r);
		if(r > mid) modify(u << 1 | 1 , l , r);
		pushup(u);
	}
}
int query(int u,int l,int r)
{
	if(tr[u].l >= l && tr[u].r <= r) return tr[u].sum;
	else{
		pushdown(u);
		int mid = tr[u].l + tr[u].r >> 1;
		int tot = 0;
		if(l <= mid) tot = query(u << 1 , l , r);
		if(r > mid) tot += query(u << 1 | 1 , l , r);
		return tot;
	}
}
void build(int u,int l,int r)
{
	if(l == r){
		tr[u] = { l , r , 0 , 0};
	}
	else{
		tr[u] = { l , r };
		int mid = l + r >> 1;
		build(u << 1 , l , mid);
		build(u << 1 | 1 , mid + 1 , r);
		pushup(u); 
	}
}
int main()
{
	ios::sync_with_stdio(0);
	cin.tie(0),cout.tie(0);
	cin >> n >> m;
	build(1 , 1 , n);
	while(m--)
	{
		int a, b, c;
		cin >> a >> b >> c;
		if(!a) modify(1 , b , c);
		else cout << query(1 , b  ,c) << endl;
	}
	return 0;
}

回复

2 条回复,欢迎继续交流。

正在加载回复...