灯泡开关

初始时有 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);
    }

猜你喜欢

转载自www.cnblogs.com/blog-of-zxf/p/11329753.html