社区讨论

希望大神们可以解一下这道题

灌水区参与者 4已保存回复 4

讨论操作

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

当前回复
4 条
当前快照
1 份
快照标识符
@lrc5ufrp
此快照首次捕获于
2024/01/13 22:26
2 年前
此快照最后确认于
2024/01/14 10:40
2 年前
查看原帖
题意为: 有2021个灯,也有2021个人,每个人都有自己的编号。(如第1个人,编号为1)每个人将自己编号的倍数的灯进行反方向操作(如果灯是开的,则关掉,否则打开),重复到2021个人,还剩多少个灯开着

这是我的代码:
CPP
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int s=0;
	bool a[2021]={false};
	for(int i=1;i<=2021;i++){
		for(int j=i;j<=2021;j++){
			if(j%i==0){
				if(a[i]==false) a[i]=true;
				else a[i]=false;
			}
		}
	}
	for(int i=1;i<=2021;i++){
		if(a[i]==true){
			s++;
		}
	}
	cout<<s;
return 0;
}

回复

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

正在加载回复...