鱼C论坛

 找回密码
 立即注册
查看: 3119|回复: 7

摩尔投票法答案没看懂

[复制链接]
发表于 2023-7-22 17:12:03 | 显示全部楼层 |阅读模式

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

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

x
题目,动动手第1题,https://fishc.com.cn/thread-172177-1-1.html
这是答案
  1. nums = [2, 2, 4, 2, 3, 6, 2]
  2.    
  3. # 对抗阶段
  4. major = nums[0]
  5. count = 0
  6. for each in nums:
  7.     if count == 0:
  8.         major = each
  9.     if each == major:
  10.         count += 1
  11.     else:
  12.         count -= 1
  13.    
  14. # 统计阶段
  15. if nums.count(major) > len(nums) / 2:
  16.     print("主要元素是:", major)
  17. else:
  18.     print("不存在主要元素。")
复制代码

count==0那里看不太懂

我觉得我的代码好理解些,但是算法确实不行
  1. s = [2, 2, 4, 2, 3, 6, 2]
  2. vote = 0
  3. each = 0
  4. i = 0

  5. for each in range(len(s)):
  6.     candidate = s[each]
  7.     vote = 0
  8.     for i in range(len(s)):
  9.         if candidate == s[i]:
  10.             vote += 1
  11.         else:
  12.             vote -= 1
  13.     if vote > 0:
  14.         print(candidate)
  15.         break
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-2 06:06

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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