leetcode 169(摩尔投票)

Problem: 169. 多数元素

思路

这里选择采用摩尔投票的方式进行计算众数,这里众数的定义是超过一半的数, 假设众数的票为+1, 负数的票为-1, 则不难得到:

  1. 当目前的票数为0时, 后面的众数仍然是整个数组的众数. 根据这个性质设计算法
  2. 所有数的票面值和为正数

解题方法

初始化众数为nums[0], vote=0, 计算票面值和, 如果vote=0则将众数更新为后一个

复杂度

时间复杂度:

O(n)

空间复杂度:

O(1)

Code

class Solution {
public:
int majorityElement(vector<int>& nums) {
int n=nums.size();
int count=n/2;
int vote=0,x=nums[0];
for (size_t i = 0; i < n; i++)
{
if(nums[i]==x) vote++;
else vote--;
if(vote==0) x=nums[i+1];
}
return x;
}
};
posted @   oxidationreaction  阅读(9)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示