码迷,mamicode.com
首页 > 其他好文 > 详细

灯泡开关

时间:2019-08-09 23:17:00      阅读:101      评论:0      收藏:0      [点我收藏+]

标签:转化   问题   sqrt   例子   解析   开关   第一个   打开   著作权   

初始时有 n 个灯泡关闭。 第 1 轮,你打开所有的灯泡。 第 2 轮,每两个灯泡你关闭一次。 第 3 轮,每三个灯泡切换一次开关(如果关闭则开启,如果开启则关闭)。第 i 轮,每 i 个灯泡切换一次开关。 对于第 n 轮,你只切换最后一个灯泡的开关。 找出 n 轮后有多少个亮着的灯泡。

示例:

输入: 3

输出: 1

解释:

初始时, 灯泡状态 [关闭, 关闭, 关闭].

第一轮后, 灯泡状态 [开启, 开启, 开启].

第二轮后, 灯泡状态 [开启, 关闭, 开启].

第三轮后, 灯泡状态 [开启, 关闭, 关闭].

你应该返回 1,因为只有一个灯泡还亮着。

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/bulb-switcher 著作权归领扣网络所有。

 

解析:举个例子:n=10,一开始所有灯泡都是关着的。

第一个位置,1*1=1,状态被改变了1次;

第二个位置,1*2=2,被改变了2次(1,2);

第三个位置,1*3=3,被改变了2次(1,3);

第四个位置(注意这里有新东西),1*4=4,2*2=4,被改变了3次(1,2,4);

第五个位置,1*5=5,被改变了2次(1,5);

.........

第八个位置,1*8=8,2*4=8,被改变了4次(1,2,4,8);

第九个位置,1*9=9,3*3=9,被改变了3次(1,3,9);

第十个位置,1*10=10,2*5=10,被改变了4次(1,2,5,10);

 

规律:凡是能开平方的位置(包括位置1)都改变了基数次,其他为偶数次(因为这些因数成对出现)。而且状态改变基数次的位置保持亮的状态,偶数次的位置状态则为关。

  所以问题转化为求n以及n以下所有能开方的数的个数即可;

  

    public int bulbSwitch(int n) {
        return (int)Math.sqrt(n);
    }

 

灯泡开关

标签:转化   问题   sqrt   例子   解析   开关   第一个   打开   著作权   

原文地址:https://www.cnblogs.com/blog-of-zxf/p/11329753.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!