题目描述
Farmer John tries to keep the cows sharp by letting them play with intellectual toys. One of the larger toys is the lights in the barn. Each of the N(2≤N≤105) cow stalls conveniently numbered 1…N has a colorful light above it.
At the beginning of the evening, all the lights are off. The cows control the lights with a set of N pushbutton switches that toggle the lights; pushing switch i changes the state of light i from off to on or from on to off.
The cows read and execute a list of M(1≤M≤105)operations expressed as one of two integers ( 0≤0≤ operation ≤1 ).
The first kind of operation (denoted by a 00 command) includes two subsequent integers SiSi and Ei(1≤Si≤Ei≤N) that indicate a starting switch and ending switch. They execute the operation by pushing each pushbutton from SiSi through Ei inclusive exactly once.
The second kind of operation (denoted by a 1 command) asks the cows to count how many lights are on in the range given by two integers Siand Ei(1≤Si≤Ei≤N) which specify the inclusive range in which the cows should count the number of lights that are on.
Help FJ ensure the cows are getting the correct answer by processing the list and producing the proper counts.
农夫约翰试图让奶牛玩智力玩具来保持它们的敏锐。谷仓里的灯是较大的玩具之一。N(2≤N≤105) 个牛栏编号为 1…N,每个牛栏上面都有一盏灯。起初所有的灯都关着。
共有 M 次操作,分为两种。
- 指定一个区间 [Si,Ei],然后改变编号在这个区间内的灯的状态(把开着的灯关上,关着的灯打开);
- 指定一个区间 [Si,Ei],要求你输出这个区间内有多少盏灯是打开的。
输入格式
第1行: 用空格隔开的两个整数 N
和 M
,N
是灯数。
第2...M+1
行: 每行表示一个操作,有三个用空格分开的整数: 指令号, S_i
和 E_i
。
若指令号为0,则表示改变 [S_i, E_i]
区间内的灯的状态(把开着的灯关上,关着的灯打开)。
若指令号为1,则表示输出 [S_i, E_i]
这个区间内有多少盏灯是打开的。
输出格式
无
输入输出样例
输入#1
4 5
0 1 2
0 2 4
1 2 3
0 2 4
1 1 4
输出#1
2
说明/提示
数据点编号 | N | M |
---|---|---|
1 ~ 2 | ≤ 100 | ≤ 100 |
3 ~ 4 | ≤ 1000 | ≤ 1000 |
5 ~ 6 | ≤ 10000 | ≤ 10000 |
7 ~ 8 | ≤ 10⁵ | ≤ 100 |
9 ~ 10 | ≤ 100 | ≤ 10⁵ |
11 ~ 12 | ≤ 1000 | ≤ 10⁵ |
13 ~ 14 | ≤ 10⁵ | ≤ 1000 |
15 ~ 16 | ≤ 10000 | ≤ 10000 |
17 ~ 18 | ≤ 10 | ≤ 10⁵ |
19 ~ 20 | ≤ 2000 | ≤ 10⁶ |
思路:
纯暴力就好了。
#include <iostream>
#include <vector>
using namespace std;const int MAX_N = 1e5 + 5;
bool lights[MAX_N];
int prefixSum[MAX_N]; int main() {ios::sync_with_stdio(false);cin.tie(0);int N, M;cin >> N >> M;fill(lights, lights + N + 1, false);fill(prefixSum, prefixSum + N + 1, 0);for (int i = 0; i < M; ++i) {int op, s, e;cin >> op >> s >> e;if (op == 0) { for (int j = s; j <= e; ++j) {lights[j] = !lights[j]; }}else if (op == 1) { int cnt = 0;for (int j = s; j <= e; ++j){if (lights[j]) {++cnt; }}cout << cnt << '\n';}}return 0;
}