【数据结构与算法Trip第4站】摩尔投票法

摩尔投票法

针对问题

当需要找寻一个数组中,存在某个数字出现的次数大于数组长度一半时。(等于情况不一定成立)

思路​:

  • 假设第一个数字是候选多数元素 candidate,并初始化计数器 count = 1。

  • 遍历数组:

  • 如果当前数字等于 candidate,则 count += 1。

  • 否则 count -= 1。

  • 如果 count == 0,则更换 candidate为当前数字,并重置 count = 1。

  • 最后剩下的 candidate就是多数元素。

​为什么有效?​​

  • 因为多数元素的数量比其他所有元素的总和还多,所以它一定能"战胜"其他数字。

​时间复杂度​:O(n)(只需遍历一次)

​空间复杂度​:O(1)(只用了常数空间)

相关题目:力扣169

相关推荐
大闲在人16 分钟前
8. 供应链与制造过程术语:产能
算法·制造·供应链管理·智能制造·工业工程
一只小小的芙厨21 分钟前
寒假集训笔记·以点为对象的树形DP
c++·算法
历程里程碑25 分钟前
普通数组----合并区间
java·数据结构·python·算法·leetcode·职场和发展·tornado
执风挽^42 分钟前
Python基础编程题2
开发语言·python·算法·visual studio code
Z9fish1 小时前
sse哈工大C语言编程练习20
c语言·开发语言·算法
晓13131 小时前
第六章 【C语言篇:结构体&位运算】 结构体、位运算全面解析
c语言·算法
iAkuya1 小时前
(leetcode)力扣100 61分割回文串(回溯,动归)
算法·leetcode·职场和发展
梵刹古音1 小时前
【C语言】 指针与数据结构操作
c语言·数据结构·算法
VT.馒头1 小时前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
CoderCodingNo3 小时前
【GESP】C++五级练习题 luogu-P1865 A % B Problem
开发语言·c++·算法