算法竞赛入门经典 开灯问题
2016-02-18 21:13
288 查看
/* 有n盏灯,编号为1~n,第1个人把所有灯打开,第2个人按下所有编号为2的倍数的开关(这些灯将被关掉), 第3个人按下所有编号为3的倍数的开关(其中关掉的灯被打开,开着灯将被关闭), 依此类推。一共有k个人,问最后有哪些灯开着? 输入:n和k,输出开着的灯编号。k≤n≤1000。 */ #include<stdio.h> #include<string.h> #define MAXN 1000+10 int a[MAXN]; int main(){ int i,j,n,k,first=1; memset(a,0,sizeof(a));//把数组a清零 scanf("%d%d",&n,&k); //k个人对n盏灯进行操作 for(i=1;i<=k;i++) for(j=1;j<=n;j++) if(j%i==0) a[j]=!a[j]; //输出最后剩下的灯的编号 for(i=1;i<=n;i++) if(a[i]){ if(first)first=0;//去除第一数之前的空格 else printf(" "); printf("%d",i); } printf("\n"); return 0; }
memset | ||
|
相关文章推荐
- Linux C函数参考手册(PDF版)
- 书评:《算法之美( Algorithms to Live By )》
- 动易2006序列号破解算法公布
- Ruby实现的矩阵连乘算法
- C#插入法排序算法实例分析
- Lua教程(十七):C API简介
- 简单谈谈lua和c的交互
- 超大数据量存储常用数据库分表分库算法总结
- C#数据结构与算法揭秘二
- C#冒泡法排序算法实例分析
- 算法练习之从String.indexOf的模拟实现开始
- C#算法之关于大牛生小牛的问题
- C#实现打造气泡屏幕保护效果
- C#实现的算24点游戏算法实例分析
- 举例讲解C#编程中委托的实例化使用
- 使用C#代码获取存储过程返回值
- C/C++数据对齐详细解析
- 利用C语言来求最大连续子序列乘积的方法
- c语言实现的带通配符匹配算法