鱼C论坛

 找回密码
 立即注册
查看: 2313|回复: 2

摩尔计数法

[复制链接]
发表于 2022-4-15 16:14:07 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
第022讲摩尔计数法plus
标答长这样:
  1. nums = [1, 1, 2, 1, 3, 2, 3, 2]
  2.    
  3. major1 = major2 = nums[0]
  4. count1 = count2 = 0
  5.    
  6. # 对抗阶段
  7. for each in nums:
  8.     if major1 == each:
  9.         count1 += 1
  10.         continue
  11.    
  12.     if major2 == each:
  13.         count2 += 1
  14.         continue
  15.    
  16.     if count1 == 0:
  17.         major1 = each
  18.         count1 = 1
  19.         continue
  20.    
  21.     if count2 == 0:
  22.         major2 = each
  23.         count2 = 1
  24.         continue
  25.    
  26.     count1 -= 1
  27.     count2 -= 1
  28.    
  29. # 统计阶段
  30. if nums.count(major1) > len(nums) / 3:
  31.     print(major1)
  32. if nums.count(major2) > len(nums) / 3:
  33.     print(major2)
复制代码


所以major1和major2从始至终运行一样的步骤,为什么最后会得出两个结果?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-4-15 18:37:30 | 显示全部楼层
遍历时 if 每次只运行一次就继续下次循环,结果怎么会一样
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-4-16 07:10:42 | 显示全部楼层
tiangtian 发表于 2022-4-15 18:37
遍历时 if 每次只运行一次就继续下次循环,结果怎么会一样

就是continue发挥的作用?
还有一个不明白的地方就是18行为什么要让count1=1
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-29 04:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表