闪存里有人这样提问这样:

第一轮操作所有电灯,第二轮操作第2盏,第4盏开关,以此类推,第三轮改变编号为3的倍数的电灯,第3盏,第6盏,如果原来那盏灯是亮的,就熄灭它,如果原来是灭的,就点亮它,以此类推,直到第100轮

用python解决的思路如下:

灯泡有两种状态:开和关,用 -1代表关,用1代表开。每次操作后,状态上乘以-1。

这样问题就简单多了:

# on ---> 1     off ---> -1

dic = {k:-1 for k in range(1,101)}

def foo(n):
for i in range(1,n+1):
for x in dic:
if x%i == False:
dic[x] = int(dic[x])*-1 return dic num = len({k: v for k,v in foo(100).items() if v == 1})
print(f"There are {num} lights on.") #There are 10 lights on.

最新文章

  1. nginx之location匹配优先级和安全问题
  2. PHP程序员进阶学习书籍参考指南
  3. UpdatePanel 中 导出Excel按钮
  4. Java提高篇---List总结
  5. Windows7隐藏字体
  6. spring(三)----大概是最简单的面向切面了
  7. [Java] Eclipse注释模板设置详解
  8. List中toArray()的使用方法
  9. Pascal's Triangle II 解答
  10. CentOS6.5 安装mysql5.6.30
  11. 使用ADO.NET查询和操作数据库
  12. MySQL读取Binlog日志常见的3种错误
  13. [Swift]LeetCode525. 连续数组 | Contiguous Array
  14. 04 Django REST Framework 认证、权限和限制
  15. 定时调度任务quartz
  16. PE文件结构解析
  17. SpringMVC由浅入深day01_8springmvc和mybatis整合
  18. 【大数据系列】Hive安装及web模式管理
  19. hadoop学习笔记(八):MapReduce
  20. ExtJs的Reader

热门文章

  1. 【前端学习笔记02】JavaScript字符串、数组的一些操作方法
  2. MVC4中control的增删改查
  3. java 父类的引用调用自己的属性 但是调用的方法必须是重写过的父类的方法 因为编译时候把他当作父类 运行时候才是他自己 所以必须重写父类得方法
  4. CF708C-Centroids
  5. 【bzoj4425】[Nwerc2015]Assigning Workstations分配工作站 贪心+堆
  6. 【JavaScript】JAVA-input如何占满整个td
  7. php配置说明
  8. Linux (四)其他一些服务的实现
  9. Winform中的Treeview动态绑定数据库
  10. 解决SpringMVC put,patch,delete请求数据拿不到的问题