开灯问题

开灯问题

时间限制: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;
}        


阅读更多
个人分类: 基础入门
上一篇重建二叉树
下一篇开灯问题
想对作者说点什么? 我来说一句

算法入门之开灯问题

2013年05月09日 64KB 下载

没有更多推荐了,返回首页

关闭
关闭