100 盏灯,全部关闭,第一人全部打开(亮)

探讨了100盏初始关闭的灯,在经历100轮开关操作后的状态,每轮由一个人操作,从第一盏灯开始,每隔一定数量的灯进行开关操作,最终确定亮着的灯的数量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

100 盏灯,全部关闭,第一人全部打开(亮),第二个人隔一个按开关(2、4、6、8、10), 第三个人隔 2 个按开关(3、6、9、12),以此类推,第 100 人路过时有几盏灯亮着?
根据题意简单实现。不知道对不对。。

nums = [1 for _ in range(100)]
mark = 1
i = 2
while i <=100:
    while mark<100:
        if nums[mark]:nums[mark]=0
        else:nums[mark]=1
        mark+=i
    mark = i
    i+=1
count=0
for i in nums:
    if i:count+=1
print(count)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值