1 /*灯光师小明 2 时间限制:1000 ms | 内存限制:65535 KB 3 难度:1 4 描述 5 灯光师小明控制着各种晚会的各种大小灯,每次晚会小明都会对灯进行很多次操作。对每盏灯只能进行两种操作,开和关。现在小明希望自己随时都知道还有多少盏灯亮着。 6 你需要编写一个程序当小明问你时你能快速的说出还有多少盏灯亮着,晚会开始时所有的灯都是灭的。 7 输入 8 只有一组数据第一行输入两个正整数N,T(0<N<=100000,0<T<=1000000)N表示有N盏灯,T表示有T条指令。随后T行每行有一条指令,这条指令包含一个字符串,当 9 字符串为CHANGE,它后面还有一个整数m,表示对第m盏灯进行一次操作(操作表示如果第m盏灯灯是开着时就关闭,如果灯是关着时就打开)。当字符串为QUERY, 10 表示小明想查询现在还有多少盏灯亮着。 11 输出 12 每次查询指令输出占一行,输出当前亮着灯的个数 13 样例输入 14 10 8 15 CHANGE 1 16 QUERY 17 CHANGE 2 18 QUERY 19 CHANGE 1 20 CHANGE 9 21 CHANGE 7 22 QUERY样例输出 23 1 24 2 25 3 26 来源 27 [路过这]原创 28 上传者 29 路过这 30 */ 31 #include<stdio.h> 32 #include<string.h> 33 int a[100010]; 34 int main() 35 { 36 int T, N, i, m, j, num = 0; 37 scanf("%d%d",&N, &T); 38 while( T-- ) 39 { 40 char s[10] = {'\0'}; 41 scanf("%s", s ); 42 if( strlen( s ) == 6) 43 { 44 scanf("%d", &m); 45 if( a[m-1] ) 46 { 47 a[m-1] = 0; 48 num--; 49 } 50 else 51 { 52 a[m-1] = 1; 53 num++; 54 } 55 } 56 else 57 printf("%d\n", num); 58 } 59 return 0; 60 }