关闭

开灯问题

332人阅读 评论(0) 收藏 举报
分类:

开灯问题

时间限制:3000 ms  |  内存限制:65535 KB
难度:1
描述

有n盏灯,编号为1~n,第1个人把所有灯打开,第2个人按下所有编号为2 的倍数的开关(这些灯将被关掉),第3 个人按下所有编号为3的倍数的开关(其中关掉的灯将被打开,开着的灯将被关闭),依此类推。一共有k个人,问最后有哪些灯开着?输入:n和k,输出开着的灯编号。k≤n≤1000

输入
输入一组数据:n和k
输出
输出开着的灯编号
样例输入
7 3
样例输出
1 5 6 7
 
#include<stdio.h>

int main()
{//1:close 0:open
	int a[1005];
	int n, k;
	int i, j;
	scanf("%d%d", &n, &k);
	for(i = 0; i <= n; i++)//n 个灯初始化
		a[i] = 0;
	for(i = 2; i <=k; i++){//k个人
		for(j = i; j <= n; j+= i){//n盏灯的状态变的与之前状态相反
			a[j] = !a[j]; 
		}
	}

	for(i = 1; i <= n; i++)
		if(a[i] == 0)
			printf("%d ", i);
	printf("\n");
	return 0;
}        


0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:41676次
    • 积分:1233
    • 等级:
    • 排名:千里之外
    • 原创:84篇
    • 转载:13篇
    • 译文:0篇
    • 评论:1条
    最新评论