LeetCode 319: Bulb Switcher (Python3)

题目

There are n bulbs that are initially off. You first turn on all the bulbs. Then, you turn off every second bulb. On the third round, you toggle every third bulb (turning on if it's off or turning off if it's on). For the ith round, you toggle every i bulb. For the nth round, you only toggle the last bulb. Find how many bulbs are on after n rounds.

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

思路

注意到,对第K个灯泡(K从0到n-1),在第i轮,当且仅当(K + 1) % i = 0时,灯泡的状态会翻转。
在第一轮,所有灯泡都被点亮。灯泡K在n轮后依然是点亮的,则灯泡K在2到n轮间被翻转了偶数次。
等价于,在[2, n]中有偶数个轮次满足(K + 1) % i = 0。
等价于,K + 1在[2, n]间有偶数个因子。
等价于,K + 1在[2, K]间有奇数个因子。(K+1本身已被除去)
现在注意到,如果(K + 1) / j = i是整数,则i, j都是K + 1的因子,因子数量应该是偶数个。但K + 1有奇数个因子,那么就存在一个数i, (K + 1) / j = i, 并且i = j。换句话说,K+1自身就是一个完全平方数。

结论:亮灯数等于[1, n]内的完全平方数个数,即:

代码

代码只需要一行。

class Solution(object):
    def bulbSwitch(self, n):
        """
        :type n: int
        :rtype: int
        """
        return int(n ** 0.5)
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • "use strict";function _classCallCheck(e,t){if(!(e instanc...
    久些阅读 2,053评论 0 2
  • 问题: There are n bulbs that are initially off. You first t...
    Cloudox_阅读 237评论 0 0
  • 今天是白巫师波符的第十三天,宇宙的白世界桥,对应的镜像是磁性的老鹰。 关键词:信任 我的启发: 宇宙的调性让我想到...
    小小斐阅读 165评论 0 1
  • 一、什么是运营? 我把运营看作是建立连接河两岸的桥,产品和用户分别是河的两岸。 产品和用户要产生关系可以通过两种渠...
    From需求池阅读 351评论 0 3
  • 从今天开始记录读过的书籍,并简要说下读后感和推荐度。 技术类 iOS 编写高质量iOS与OS X代码的52个有效方...
    Jack_deng阅读 160评论 0 0