鱼C论坛

 找回密码
 立即注册
查看: 2364|回复: 6

[已解决]列表四作业

[复制链接]
头像被屏蔽
发表于 2023-4-10 18:10:49 | 显示全部楼层 |阅读模式
提示: 作者被禁止或删除 内容自动屏蔽
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-4-10 18:11:48 | 显示全部楼层    本楼为最佳答案   
本帖最后由 sfqxx 于 2023-4-10 18:13 编辑

在这段代码中,“对抗阶段”是指找出列表中出现次数最多的两个元素。为此,我们使用major1和major2两个变量来保存当前两个出现次数最多的元素,count1和count2变量分别表示它们的出现次数。

遍历列表时,对于每个元素,分以下四种情况处理:

1. 如果major1等于该元素,则将count1加1,表示该元素的出现次数增加了。

2. 如果major2等于该元素,则将count2加1,表示该元素的出现次数增加了。

3. 如果count1等于0,则将该元素赋给major1,并将count1设为1,表示该元素是新的出现次数最多的元素之一。

4. 如果count2等于0,则将该元素赋给major2,并将count2设为1,表示该元素是新的出现次数最多的元素之一。

5. 如果以上4种情况均不符合,则将count1和count2都减1,表示当前的两个出现次数最多的元素都没有找到与该元素匹配的元素,需要进一步查找。

通过这样的处理方式,在遍历完成后,major1和major2变量所保存的就是列表中出现次数最多的两个元素。
有用请设置最佳答案
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-4-10 18:12:43 | 显示全部楼层

不要占楼
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-4-10 18:13:20 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-4-10 18:13:35 | 显示全部楼层
在对抗阶段中,我们通过比较当前元素和 major1、major2 是否相等来判断当前元素是哪个元素的候选项。如果当前元素和 major1 相等,则 count1 加 1;如果当前元素和 major2 相等,则 count2 加 1。如果当前元素和 major1、major2 都不相等,则将其作为新的候选项之一,如果 count1 为 0,则将其设置为 major1;如果 count2 为 0,则将其设置为 major2。
如果当前元素既不是 major1 也不是 major2,则 count1 和 count2 都要减去 1。这是因为如果当前元素和 major1、major2 都不相等,说明它不是众数,我们需要将其从候选项中删除。由于我们使用了两个候选项,所以在对抗阶段中,我们需要将两个候选项分别与当前元素进行比较,并分别更新它们的计数器。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-4-10 18:13:36 | 显示全部楼层
在对抗阶段,该算法使用了摩尔投票法的变种来寻找列表 nums 中出现次数最多的两个元素 major1 和 major2。

具体过程如下:

  • 初始化 major1 和 major2 为列表中的第一个元素 nums[0],并将它们的出现次数都初始化为 0。
  • 遍历列表中的每个元素 each。
  • 如果 major1 与 each 相等,则将 count1 加 1。
  • 否则,如果 major2 与 each 相等,则将 count2 加 1。
  • 否则,如果 count1 为 0,则将 major1 更新为 each,并将 count1 加 1。
  • 否则,如果 count2 为 0,则将 major2 更新为 each,并将 count2 加 1。
  • 否则,如果 major1、major2 和 each 都不相等,那么说明 major1 和 major2 都不是出现次数最多的元素,因此将 count1 和 count2 都减 1。
  • 最终,major1 和 major2 分别代表列表中出现次数最多的两个元素。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-4-10 20:14:15 | 显示全部楼层
OK
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-29 09:26

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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