当前位置:首页 > 编程笔记 > 正文
已解决

leetcode - 319. Bulb Switcher

来自网友在路上 138838提问 提问时间:2023-10-20 06:44:07阅读次数: 38

最佳答案 问答题库388位专家为你答疑解惑

Description

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.

Return the number of bulbs that are on after n rounds.

Example 1:
在这里插入图片描述

Input: n = 3
Output: 1
Explanation: At first, the three bulbs are [off, off, off].
After the first round, the three bulbs are [on, on, on].
After the second round, the three bulbs are [on, off, on].
After the third round, the three bulbs are [on, off, off]. 
So you should return 1 because there is only one bulb is on.

Example 2:

Input: n = 0
Output: 0

Example 3:

Input: n = 1
Output: 1

Constraints:

0 <= n <= 109

Solution

Solved after others’ solutions…

Ref: https://leetcode.com/problems/bulb-switcher/solutions/77104/math-solution/

A bulb ends up on iff it is switched an odd number of times.

Call them bulb 1 to bulb n. Bulb i is switched in round d if and only if d divides i. So bulb i ends up on if and only if it has an odd number of divisors.

Divisors come in pairs, like i=12 has divisors 1 and 12, 2 and 6, and 3 and 4. Except when i is a square, like 36 has divisors 1 and 36, 2 and 18, 3 and 12, 4 and 9, and double divisor 6. So bulb i ends up on if and only if i is a square.

So just count the square numbers.

Let R = int(sqrt(n)). That’s the root of the largest square in the range [1,n]. And 1 is the smallest root. So you have the roots from 1 to R, that’s R roots. Which correspond to the R squares. So int(sqrt(n)) is the answer.

Time complexity: o ( 1 ) o(1) o(1)
Space complexity: o ( 1 ) o(1) o(1)

Code

class Solution:def bulbSwitch(self, n: int) -> int:return int(sqrt(n))
查看全文

99%的人还看了

猜你感兴趣

版权申明

本文"leetcode - 319. Bulb Switcher":http://eshow365.cn/6-20129-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!