摩尔投票算法
摩尔投票算法
摩尔投票算法是一种用于在数组中查找出现次数超过一半的元素的有效算法。算法的核心思想是利用候选元素和[计数器](https://so.csdn.net/so/search?q=%E8%AE%A1%E6%95%B0%E5%99%A8&spm=1001.2101.3001.7020)进行投票,通过消除不同元素之间的抵消来找到出现次数超过一半的元素。
算法原理
如果数组中存在一个出现次数超过一半的元素,那么这个元素的剩余部分一定会抵消其他元素的出现次数,最终剩下的就是该元素。
算法步骤
- 初始化候选元素 candidate 为数组的第一个元素,计数器 count 为 1。
- 从数组的第二个元素开始遍历。
- 如果当前元素与候选元素相同,则将计数器 count 加 1。
- 如果当前元素与候选元素不同,则将计数器 count 减 1。
- 如果计数器 count 减为零,则更新候选元素为当前元素,并将计数器 count 重置为 1。
- 完成遍历后,候选元素就是出现次数超过一半的元素。
实例
例子:
假设数组为 [2, 2, 1, 1, 1, 2, 2]。
- 初始时,候选元素 candidate 为 2,计数器 count 为 1。
- 开始遍历数组:
- 遍历到 2,与候选元素相同,计数器 count 加 1,计数器变为 2。
- 遍历到 1,与候选元素不同,计数器 count 减 1,计数器变为 1。
- 遍历到 1,与候选元素不同,计数器 count 减 1,计数器变为 0。
- 计数器 count 变为 0,更新候选元素为当前元素 1,计数器 count 重置为 1。
- 遍历到 1,与候选元素相同,计数器 count 加 1,计数器变为 2。
- 遍历到 2,与候选元素相同,计数器 count 加 1,计数器变为 1。
- 遍历到 2,与候选元素相同,计数器 count 加 1,计数器变为 0。
- 计数器count变为0,更新候选元素为当前元素2,计数器count重置为2
- 完成遍历后,候选元素为 2,它是出现次数超过一半的元素
LeetCode算法题
给定一个大小为
n
的数组nums
,返回其中的多数元素。多数元素是指在数组中出现次数 大于⌊ n/2 ⌋
的元素。你可以假设数组是非空的,并且给定的数组总是存在多数元素。
示例 1:
输入:nums = [3,2,3]
输出:3示例 2:
输入:nums = [2,2,1,1,1,2,2]
输出:2
解法
- 初始化: 票数统计
vote = 0
, 众数x
。- 循环: 遍历数组
nums
中的每个数字num
。
- 当 票数
vote
等于 0 ,则假设当前数字num
是众数。- 当
num = x
时,票数vote
自增 1 ;当num != x
时,票数vote
自减 1 。- 返回值: 返回
x
即可。
1 | class Solution { |
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 Gzzz's Blog!
评论