开灯问题

原创 2013年12月04日 22:30:11

开灯问题

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


C语言开灯问题的源代码

  • 2017年08月13日 21:25
  • 445B
  • 下载

23-语言入门-23-开灯问题

题目地址: http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=77 描述 有n盏灯,编号为1~n,第1个人把所有灯打开,第2个人按下所有...

算法入门经典:开灯问题

算法入门经典:开灯问题 前言:一直很羡慕那些善于写算法的同学,感觉他们真的很聪明,不想我这么笨,一思考算法就头疼。罢了,从最简单的开始吧,加油。 问题: 有n盏灯,编...
  • MissXy_
  • MissXy_
  • 2017年08月02日 21:12
  • 303

NYOJ_77 开灯问题

k个人开n盏灯,输出最后的哪些灯开着

1151: 零起点学算法58——开灯问题

1151: 零起点学算法58——开灯问题 时间限制: 1 Sec  内存限制: 64 MB [提交][状态][讨论版] Problem Description 计算中心有8个机房,每个机房...

Switch Game<开灯问题>关于n以内的完全平方数个数求解

Switch Game Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) To...

算法竞赛入门经典_3.1_数组_逆序输出_开灯问题

又是新的一天,继续更新. 今天进入了新的章节,数组和字符串 1.逆序输出问题: 先来看代码吧 #include //逆序输出 2017-8-16 #define maxn 105 int a[ma...
  • cre2017
  • cre2017
  • 2017年11月23日 12:51
  • 23

开灯问题

描述 有n盏灯,编号为1~n,第1个人把所有灯打开,第2个人按下所有编号为2 的倍数的开关(这些灯将被关掉),第3 个人按下所有编号为3的倍数的开关(其中关掉的灯将被打开,开着的灯将被关闭),依此类...

UVA 10110 Light, more light【经典开灯问题】

Light, more light Time Limit: 3000ms Memory Limit: 131072KB This problem will be judged on ...

智力题 开灯问题

题目: 对一批编号为1-100,全部开关朝上(开)的灯进行以下操作:凡是1的倍数反方向拨一次开关;2的倍数反方向又拨一次开关;3的倍数反方向又拨一次开关……问:最后为关熄状态的灯的编号是哪些? 分...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:开灯问题
举报原因:
原因补充:

(最多只允许输入30个字)