现在有100个标记过的电灯泡。第一个人经过这些灯时,点亮所有的灯,第二个人经过时每隔一盏灯就切换开关一次,第三个人经过时每隔两盏灯切换开关一次。请问,当第100个人经过时,还剩多少盏亮着的灯?
2012-06-11 17:47
477 查看
偶然看到腾讯一个报道《15道烧糊大脑的苹果面试题》,里面有些很好算法题,就自己动手写了一下,寻求点乐趣。
出处URL:http://tech.qq.com/a/20120611/000062.htm#p=8
输出结果:
希望大家有更好的算法,提供些思路,共同进步。
+
![](http://static.blog.csdn.net/xheditor/xheditor_emot/default/struggle.gif)
补充:谢谢大家的回复,让我收益颇多,下面我做了些总结:
做了一个草图:10(纵10人)X10(横10栈灯)
第一个人:1 1 1 1 1 1 1 1 1 1
第二个人:0 1 0 1 0 1 0 1 0 1
第三个人:0 0 1 0 0 1 0 0 1 0
第四个人:0 0 0 1 0 0 0 1 0 0
第五个人:0 0 0 0 1 0 0 0 0 1
第六个人:0 0 0 0 0 1 0 0 0 0
第七个人:0 0 0 0 0 0 1 0 0 0
第八个人:0 0 0 0 0 0 0 1 0 0
第九个人:0 0 0 0 0 0 0 0 1 0
第十个人:0 0 0 0 0 0 0 0 0 1
从上面的片段中我们看到,第一盏灯:1,第二盏灯:1、2 第三盏灯:1、3 第四盏灯:1、2、4 第五盏灯:1、5 第六盏灯:1、2、3、6 第七盏灯:1、7 第八盏灯:1、2、4、8 第九盏灯:1、3、9 第四盏灯:1、2、5、10 略。
综上:相信大家已经看出来了:
凡是最后亮的灯,都被按过奇数次每盏灯被按的次数,即等于它的约数的个数,比如8号灯,它被第1、2、4、8这四个人按到,所以最后是灭的状态,再比如16号灯,它被第1、2、4、8、16这五个人按到,所以最后是开的状态。
结论:最后,只有完全平方数,其约数个数为奇数,就是亮灯的情况。
这其实就是纯粹的数学问题,没有必要用code去实现了。
出处URL:http://tech.qq.com/a/20120611/000062.htm#p=8
public class AppleDemo00 { /** * @author 州伟 * @param args * 现在有100个标记过的电灯泡。第一个人经过这些灯时,点亮所有的灯,第二个人经过时每隔一盏灯就切换开关一次, * 第三个人经过时每隔两盏灯切换开关一次。 * 请问,当第100个人经过时,还剩多少盏亮着的灯? */ public static void main(String[] args) { //初始化一个数组 ,数组元素 0:关灯、1:开灯 int[] preLights = new int[100]; //初始化元素都为0,默认关灯 for(int a : preLights){ System.out.print(a + " "); } for(int i=1;i<=100;i++){ //100个人 for(int j=0;j<100;j=j+i){ // if(j==0 && i==1){ //第一个人路过时,第一站灯 preLights[j] = turnOnorOffLight(preLights[j]); }else{ if(j>1){ preLights[j-1] = turnOnorOffLight(preLights[j-1]); } } } } System.out.println(); System.out.println("输出------------------"); //输出 for(int a : preLights){ System.out.print(a + " "); } //输出描述 System.out.println(); for(int i=0;i<100;i++){ if(preLights[i] != 0){ System.out.print(i+1 + ", "); } } System.out.println(); //发现:结果是完全平方数 System.out.println("综上发现:结果是完全平方数:1*1,2*2,3*3,4*4,5*5,6*6,7*7,8*8,9*9,是否有更好的算法呢???"); } private static int turnOnorOffLight(int a){ switch (a) { case 0: return 1; case 1: return 0; } return -1; } }
输出结果:
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 输出------------------ 1 0 0 1 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1, 4, 9, 16, 25, 36, 49, 64, 81, 综上发现:结果是完全平方数:1*1,2*2,3*3,4*4,5*5,6*6,7*7,8*8,9*9,是否有更好的算法呢(看补充)!
希望大家有更好的算法,提供些思路,共同进步。
+
![](http://static.blog.csdn.net/xheditor/xheditor_emot/default/struggle.gif)
补充:谢谢大家的回复,让我收益颇多,下面我做了些总结:
做了一个草图:10(纵10人)X10(横10栈灯)
第一个人:1 1 1 1 1 1 1 1 1 1
第二个人:0 1 0 1 0 1 0 1 0 1
第三个人:0 0 1 0 0 1 0 0 1 0
第四个人:0 0 0 1 0 0 0 1 0 0
第五个人:0 0 0 0 1 0 0 0 0 1
第六个人:0 0 0 0 0 1 0 0 0 0
第七个人:0 0 0 0 0 0 1 0 0 0
第八个人:0 0 0 0 0 0 0 1 0 0
第九个人:0 0 0 0 0 0 0 0 1 0
第十个人:0 0 0 0 0 0 0 0 0 1
从上面的片段中我们看到,第一盏灯:1,第二盏灯:1、2 第三盏灯:1、3 第四盏灯:1、2、4 第五盏灯:1、5 第六盏灯:1、2、3、6 第七盏灯:1、7 第八盏灯:1、2、4、8 第九盏灯:1、3、9 第四盏灯:1、2、5、10 略。
综上:相信大家已经看出来了:
凡是最后亮的灯,都被按过奇数次每盏灯被按的次数,即等于它的约数的个数,比如8号灯,它被第1、2、4、8这四个人按到,所以最后是灭的状态,再比如16号灯,它被第1、2、4、8、16这五个人按到,所以最后是开的状态。
结论:最后,只有完全平方数,其约数个数为奇数,就是亮灯的情况。
这其实就是纯粹的数学问题,没有必要用code去实现了。
相关文章推荐
- 现在有100个标记过的电灯泡。第一个人经过这些灯时,点亮所有的灯,第二个人经过时每隔一盏灯就切换开关一次,第三个人经过时每隔两盏灯切换开关一次。请问,当第100个人经过时,还剩多少盏亮着的灯?
- 现在有100个标记过的电灯泡。第一个人经过这些灯时,点亮所有的灯,第二个人经过时每隔一盏灯就切换开关一次,第三个人经过时每隔两盏灯切换开关一次。请问,当第100个人经过时,还剩多少盏亮着的灯?
- 有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后问第一个人,他说是10岁。请问第五个人多大?
- 题目:有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后问第一个人,他说是10岁。请问
- 有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后问第一个人,他说是10岁。请问第五个
- 有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后问第一个人,他说是10岁。请问第五个
- 有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。 问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。 问第2个人,说比第一个人大两岁。 最后问第一个人,他说是10岁。请问
- 柜子开关,经过第i轮的开关切换,柜子开着的还剩几个
- CSU 1021 从m个不同元素中取出n (n ≤ m)个元素的所有组合的个数,叫做从m个不同元素中取出n个元素的组合数。组合数的计算公式如下: C(m, n) = m!/((m - n)!n!) 现在请问,如果将组合数C(m, n)写成二进制数,请问转这个二进制数末尾有多少个零。
- C语言 约瑟夫圈问题:N个人围成一圈,从第一个人开始按顺序报数并编号1,2,3,……N,然后开始从第一个人转圈报数,凡是报到3的退出圈子。则剩下的最后一个人编号是多少。
- 上20阶楼梯,可以一次迈1,2,3步,请问有多少种上法?
- hdu 3433 A Task Process N个人,第i个人完成一个A任务需要时间ai,完成一个B任务需要时间bi, 现在又X个任务A和Y个任务B,求完成所有任务所需要的最短时间。
- 最近距离 已知平面上的若干点的位置,存入一个List中。现在需要计算所有这些点中, 距离最近的两个点间的最小距离。请补全缺失的代码。
- 递归题:话说一个小球从100米空中落下,每次反弹一半高度,请问第12次反弹的高度是多少,小球总共经过多少米?
- 请问大家,知不知道,现在有没有点对点,P2P的流媒体软件吗?或者什么公司或者个人已经有产品了?
- 请问大家,知不知道,现在有没有点对点,P2P的流媒体软件吗?或者什么公司或者个人已经有产品了?
- (循环语句)小芳的妈妈每天给她2.5元钱,她都会存起来,但是,每当这一天是存钱的第5天或者5的倍数的话,她都会花去6元钱,请问,经过多少天,小芳才可以存到100元钱。(面试)
- Interview Q&A - 房间里有三盏灯,屋里有三个开关分别控制这三盏灯。如何只进入房间一次就知道哪一个开关控制哪一盏灯?
- 一个小球从100米空中落下,每次反弹一半高度,小球总共经过多少米,请问第10次反弹的高度是多少
- GIT 版本控制软件的常用命令记录每次更新到仓库 现在我们手上已经有了一个真实项目的 Git 仓库,并从这个仓库中取出了所有文件的工作拷贝。接下来,对这些文件作些修改,在完成了一个阶段的目标和使用方法