题目描述
在一条无限长的路上,有一排无限长的路灯,编号为 1,2,3,4,…1,2,3,4,…。
每一盏灯只有两种可能的状态,开或者关。如果按一下某一盏灯的开关,那么这盏灯的状态将发生改变。如果原来是开,将变成关。如果原来是关,将变成开。
在刚开始的时候,所有的灯都是关的。小明每次可以进行如下的操作:
指定两个数,𝑎,𝑡a,t(𝑎a 为实数,𝑡t 为正整数)。将编号为 ⌊𝑎⌋,⌊2×𝑎⌋,⌊3×𝑎⌋,…,⌊𝑡×𝑎⌋⌊a⌋,⌊2×a⌋,⌊3×a⌋,…,⌊t×a⌋ 的灯的开关各按一次。其中 ⌊𝑘⌋⌊k⌋ 表示实数 𝑘k 的整数部分。
在小明进行了 𝑛n 次操作后,小明突然发现,这个时候只有一盏灯是开的,小明很想知道这盏灯的编号,可是这盏灯离小明太远了,小明看不清编号是多少。
幸好,小明还记得之前的 𝑛n 次操作。于是小明找到了你,你能帮他计算出这盏开着的灯的编号吗?
说明/提示
记 𝑇=∑𝑖=1𝑛𝑡𝑖=𝑡1+𝑡2+𝑡3+⋯+𝑡𝑛T=i=1∑nti=t1+t2+t3+⋯+tn。
- 对于 30%30% 的数据,满足 𝑇≤1000T≤1000;
- 对于 80%80% 的数据,满足 𝑇≤200000T≤200000;
- 对于 100%100% 的数据,满足 𝑇≤2000000T≤2000000;
- 对于 100%100% 的数据,满足 𝑛≤5000n≤5000,1≤𝑎𝑖<10001≤ai<1000,1≤𝑡𝑖≤𝑇1≤ti≤T。
数据保证,在经过 𝑛n 次操作后,有且只有一盏灯是开的,不必判错。而且对于所有的 i 来说,txa 的最大值不超过 2000000。
#include <stdio.h>
#include <stdlib.h>
int main() {
int n,t; //有n个t盏灯
int b[200005]={0}; //数字,模拟所有的灯,初始都为灭的(0)
double a;
scanf("%d",&n);
for(int i=1;i<=n;i++){ //i为在n个灯中的其中一个,做循环
scanf("%d%d",&a,&t); //输入a和t
for(int j;j<=t;j++){ //有n个a,t数组,j为t里的其中一个
int tem=j*a; //算出编号,把开的变关,关的变开,对应[a],[1xa],[2xa]...[txa]
b[tem]=1-b[tem]; //将1变成0,将0变成1
/*if(b[tem]==0) b[tem]==1
if(b[tem]==1) b[tem]==0*/
}
}
for(int i=1;i<=2000000;i++){ //查找为1的灯
if(b[i]=1){
printf("%d",i); //如果找到,输出这个灯是第几个
break;
}
}
return 0;
}