n个人编号1——n
n个灯编号1——n
第n位学生拉n的倍数的编号开关
问最后剩下几台灯亮
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int main()
{
int studentNum;
while(cin>>studentNum)
{
vector<bool>bVec(studentNum,true);
for(int i = 2;i <= studentNum;i++)
{
for(int j = 1;j <= studentNum;j++)
{
if(j % i == 0)
{
bVec[j-1] = !bVec[j-1];
}
}
}
int icount = count(bVec.begin(),bVec.end(),true);
cout<<icount<<endl;
}
system("pause");
return 0;
}